/**
 * Peach newsletter subscribe — page template only
 * Colors aligned with theme (style.css): red #ed1b24, teal #5a7c77, blue #0a5675.
 *
 * Layout: intro (+ optional page content) left, signup form right on desktop.
 * Site footer comes from footer.php only.
 *
 * @package zdvo
 */

.peach-subscribe-page {
	/* ZDVO brand — matches BH Global / donate / navbar */
	--zdvo-red: #ed1b24;
	--zdvo-red-dark: #c4141c;
	--zdvo-teal: #5a7c77;
	--zdvo-teal-dark: #4a6864;
	--zdvo-blue: #0a5675;
	--zdvo-blue-mid: #0f3d52;
	--zdvo-bg-deep: #061018;
	--zdvo-bg-mid: #0a2533;
	--zdvo-page-bg: #f4f6fa;
	--zdvo-paper: #ffffff;
	--zdvo-ink: #26211d;
	--zdvo-ink-soft: #4d4641;
	--zdvo-muted: #727272;
	--zdvo-red-soft: rgba(237, 27, 36, 0.22);
	--zdvo-blue-glow: rgba(10, 86, 117, 0.32);
	--zdvo-card-shadow: 0 12px 40px rgba(6, 16, 24, 0.08);
	--zdvo-shell-max: 940px;
	font-family: inherit;
	color: var(--zdvo-ink);
	background: var(--zdvo-page-bg);
	margin: 0;
	overflow-x: hidden;
}

.peach-subscribe-page * {
	box-sizing: border-box;
}

/* —— Hero imagery (responsive art) —— */
.peach-subscribe-hero-media {
	position: relative;
	width: 100%;
	background: var(--zdvo-bg-deep);
	line-height: 0;
	overflow: hidden;
}

.peach-subscribe-hero-media-inner {
	position: relative;
	line-height: 0;
}

.peach-subscribe-hero-media-inner::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: min(42%, 180px);
	background: linear-gradient(to bottom, transparent, var(--zdvo-bg-deep));
	pointer-events: none;
	z-index: 1;
}

.peach-subscribe-hero-media-inner picture {
	display: block;
	width: 100%;
	line-height: 0;
}

.peach-subscribe-hero-media-inner img {
	display: block;
	width: 100%;
	height: auto;
	max-height: min(82vh, 680px);
	object-fit: cover;
	object-position: center top;
	background: var(--zdvo-bg-deep);
}

@media (min-width: 768px) {
	.peach-subscribe-hero-media-inner img {
		height: min(72vh, 560px);
		max-height: none;
		object-fit: cover;
		object-position: center center;
	}
}

/* —— Hero headline band —— */
.peach-subscribe-hero {
	position: relative;
	background:
		radial-gradient(ellipse 120% 80% at 50% -20%, var(--zdvo-blue-glow), transparent 55%),
		linear-gradient(160deg, var(--zdvo-bg-deep) 0%, var(--zdvo-bg-mid) 50%, var(--zdvo-blue-mid) 100%);
	padding: 2.75rem 1.25rem 3.25rem;
	text-align: center;
	border-bottom: 1px solid rgba(237, 27, 36, 0.4);
}

@media (min-width: 768px) {
	.peach-subscribe-hero {
		padding: 3.5rem 2rem 4rem;
	}
}

.peach-subscribe-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.06) 0%, transparent 45%),
		radial-gradient(circle at 80% 70%, rgba(237, 27, 36, 0.1) 0%, transparent 40%),
		repeating-linear-gradient(
			90deg,
			transparent,
			transparent 2px,
			rgba(255, 255, 255, 0.02) 2px,
			rgba(255, 255, 255, 0.02) 3px
		);
	pointer-events: none;
	opacity: 0.85;
}

.peach-subscribe-hero-inner {
	position: relative;
	z-index: 1;
	max-width: min(92vw, var(--zdvo-shell-max));
	margin: 0 auto;
}

.peach-subscribe-kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	font-size: clamp(13px, 1.4vw, 15px);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #fff;
	background: var(--zdvo-red-soft);
	border: 1px solid rgba(237, 27, 36, 0.55);
	box-shadow: inset 0 0 0 1px rgba(10, 86, 117, 0.35);
	padding: 0.5rem 1.1rem;
	border-radius: 999px;
	margin-bottom: 1.25rem;
}

.peach-subscribe-title {
	font-family: inherit;
	font-weight: 700;
	font-size: clamp(26px, 5vw, 44px);
	line-height: 1.15;
	color: #fff;
	margin: 0 0 1rem;
	letter-spacing: -0.02em;
	text-shadow: 0 2px 24px rgba(0, 0, 0, 0.25);
}

.peach-subscribe-lead {
	font-size: clamp(16px, 2.1vw, 20px);
	line-height: 1.55;
	color: rgba(232, 237, 245, 0.95);
	margin: 0;
	max-width: 36em;
	margin-inline: auto;
}

/* —— Body: centered cluster (no dead space between copy and form) —— */
.peach-subscribe-body {
	padding: 2.25rem 0 3rem;
	background:
		radial-gradient(ellipse 75% 55% at 50% 0%, rgba(10, 86, 117, 0.07), transparent 60%),
		var(--zdvo-page-bg);
}

@media (min-width: 768px) {
	.peach-subscribe-body {
		padding: 2.75rem 0 3.5rem;
	}
}

/* Mobile: intro → form → editor (flex order) */
.peach-subscribe-layout {
	width: 100%;
	max-width: var(--zdvo-shell-max);
	margin-inline: auto;
	padding-inline: 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.peach-subscribe-intro-block {
	order: 1;
	min-width: 0;
	width: 100%;
}

.peach-subscribe-form-aside {
	order: 2;
	min-width: 0;
	width: 100%;
}

.peach-subscribe-editor {
	order: 3;
	min-width: 0;
	width: 100%;
}

/*
 * Desktop: two equal-ish columns, tight gap — whole block centered under hero.
 * Removes the “empty middle” caused by narrow copy inside a 1fr track.
 */
@media (min-width: 992px) {
	.peach-subscribe-layout {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: 1.5rem 1.75rem;
		align-items: start;
		padding-inline: 1.5rem;
		box-sizing: border-box;
	}

	.peach-subscribe-intro-block {
		grid-column: 1;
		grid-row: 1;
		order: unset;
	}

	.peach-subscribe-form-aside {
		grid-column: 2;
		grid-row: 1 / -1;
		order: unset;
		position: sticky;
		top: 1.25rem;
		align-self: start;
	}

	.peach-subscribe-editor {
		grid-column: 1;
		grid-row: 2;
		order: unset;
	}
}

@media (min-width: 1100px) {
	.peach-subscribe-layout {
		max-width: 980px;
		gap: 1.75rem 2rem;
		padding-inline: 2rem;
	}
}

/* RTL: column 1 = inline-start = right; form stays on that side */
@media (min-width: 992px) {
	[dir="rtl"] .peach-subscribe-intro-block {
		grid-column: 2;
		grid-row: 1;
	}

	[dir="rtl"] .peach-subscribe-form-aside {
		grid-column: 1;
		grid-row: 1 / -1;
	}

	[dir="rtl"] .peach-subscribe-editor {
		grid-column: 2;
		grid-row: 2;
	}
}

.peach-subscribe-intro {
	background: var(--zdvo-paper);
	border-radius: 18px;
	padding: 1.65rem 1.45rem 1.85rem;
	margin-bottom: 0;
	box-shadow: var(--zdvo-card-shadow);
	border: 1px solid rgba(10, 86, 117, 0.07);
	position: relative;
}

.peach-subscribe-intro::before {
	content: "";
	position: absolute;
	top: 0;
	left: 1.5rem;
	right: 1.5rem;
	height: 4px;
	border-radius: 0 0 6px 6px;
	background: linear-gradient(90deg, var(--zdvo-red) 0%, var(--zdvo-blue) 100%);
	opacity: 0.95;
}

@media (min-width: 768px) {
	.peach-subscribe-intro {
		padding: 2rem 2rem 2.15rem;
		border-radius: 20px;
	}

	.peach-subscribe-intro::before {
		left: 2rem;
		right: 2rem;
	}
}

.peach-subscribe-intro p {
	font-size: clamp(16px, 1.9vw, 18px);
	line-height: 1.7;
	color: var(--zdvo-ink-soft);
	margin: 0 0 1.1em;
}

.peach-subscribe-intro p:last-child {
	margin-bottom: 0;
}

.peach-subscribe-intro strong {
	color: var(--zdvo-ink);
	font-weight: 600;
}

/* —— Form panel —— */
.peach-subscribe-form-wrap {
	background: var(--zdvo-paper);
	border-radius: 18px;
	padding: 1.65rem 1.45rem 1.85rem;
	margin-bottom: 0;
	box-shadow: var(--zdvo-card-shadow);
	border: 1px solid rgba(10, 86, 117, 0.07);
	position: relative;
	overflow: hidden;
}

.peach-subscribe-form-wrap::before {
	content: "";
	position: absolute;
	top: 0;
	left: 1.45rem;
	right: 1.45rem;
	height: 4px;
	border-radius: 0 0 6px 6px;
	background: linear-gradient(90deg, var(--zdvo-blue) 0%, var(--zdvo-red) 100%);
	opacity: 0.95;
}

.peach-subscribe-form-wrap::after {
	content: "";
	position: absolute;
	width: 200px;
	height: 200px;
	right: -70px;
	top: -70px;
	background: radial-gradient(circle, rgba(10, 86, 117, 0.08) 0%, transparent 72%);
	pointer-events: none;
}

@media (min-width: 768px) {
	.peach-subscribe-form-wrap {
		padding: 2rem 2rem 2.15rem;
		border-radius: 20px;
	}

	.peach-subscribe-form-wrap::before {
		left: 2rem;
		right: 2rem;
	}
}

.peach-subscribe-form-heading {
	position: relative;
	z-index: 1;
	font-size: clamp(19px, 2.2vw, 24px);
	font-weight: 700;
	color: var(--zdvo-ink);
	margin: 0.35rem 0 0.4rem;
	letter-spacing: -0.02em;
}

.peach-subscribe-form-sub {
	position: relative;
	z-index: 1;
	font-size: 15px;
	line-height: 1.55;
	color: var(--zdvo-muted);
	margin: 0 0 1.5rem;
}

.peach-subscribe-form-inner {
	position: relative;
	z-index: 1;
}

/* MC4WP — scoped overrides */
.peach-subscribe-page .mc4wp-form {
	margin: 0;
}

.peach-subscribe-page .mc4wp-form-fields {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

.peach-subscribe-page .mc4wp-form input[type="text"],
.peach-subscribe-page .mc4wp-form input[type="email"],
.peach-subscribe-page .mc4wp-form input[type="tel"] {
	width: 100%;
	max-width: 100%;
	padding: 14px 16px;
	font-size: 16px;
	line-height: 1.4;
	border: 2px solid rgba(38, 33, 29, 0.15);
	border-radius: 12px;
	background: #fff;
	color: var(--zdvo-ink);
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.peach-subscribe-page .mc4wp-form input:focus {
	outline: none;
	border-color: var(--zdvo-blue);
	box-shadow: 0 0 0 4px rgba(10, 86, 117, 0.2);
}

.peach-subscribe-page .mc4wp-form input[type="submit"],
.peach-subscribe-page .mc4wp-form button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	margin-top: 0.35rem;
	padding: 16px 24px;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #fff !important;
	background-color: var(--zdvo-red) !important;
	background-image: none !important;
	border: 2px solid var(--zdvo-red) !important;
	border-radius: 4px;
	cursor: pointer;
	box-shadow: 0 8px 24px rgba(237, 27, 36, 0.28);
	transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.15s ease, box-shadow 0.15s ease;
}

.peach-subscribe-page .mc4wp-form input[type="submit"]:hover,
.peach-subscribe-page .mc4wp-form button[type="submit"]:hover {
	background-color: var(--zdvo-red-dark) !important;
	border-color: var(--zdvo-red-dark) !important;
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(237, 27, 36, 0.35);
}

.peach-subscribe-page .mc4wp-alert {
	margin-top: 1rem;
	padding: 12px 14px;
	border-radius: 10px;
	font-size: 14px;
	line-height: 1.45;
}

.peach-subscribe-page .mc4wp-success {
	background: rgba(90, 124, 119, 0.15);
	color: var(--zdvo-teal-dark);
	border: 1px solid rgba(90, 124, 119, 0.35);
}

.peach-subscribe-page .mc4wp-error {
	background: rgba(237, 27, 36, 0.08);
	color: var(--zdvo-red-dark);
	border: 1px solid rgba(237, 27, 36, 0.25);
}

.peach-subscribe-page .mc4wp-form label {
	font-size: 14px;
	font-weight: 600;
	color: var(--zdvo-ink-soft);
	margin-bottom: 4px;
	display: block;
}

/* Optional editor content (left column under intro on desktop) */
.peach-subscribe-editor {
	margin: 0;
	padding: 1.65rem 1.45rem 1.85rem;
	background: var(--zdvo-paper);
	border-radius: 18px;
	box-shadow: var(--zdvo-card-shadow);
	border: 1px solid rgba(10, 86, 117, 0.07);
	font-size: 16px;
	line-height: 1.65;
	color: var(--zdvo-ink-soft);
}

@media (min-width: 768px) {
	.peach-subscribe-editor {
		padding: 2rem 2rem 2.15rem;
		border-radius: 20px;
	}
}

@media (min-width: 992px) {
	.peach-subscribe-editor {
		margin-top: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.peach-subscribe-page .mc4wp-form input[type="submit"]:hover,
	.peach-subscribe-page .mc4wp-form button[type="submit"]:hover {
		transform: none;
	}

	@media (min-width: 992px) {
		.peach-subscribe-form-aside {
			position: relative;
			top: auto;
		}
	}
}
