/**
 * Servants of Mary Theme - Main Styles
 * Color palette: Cream #F8F8F5, Teal #4C8281, Gold #C09A52/#D4AF37, Text #2C3E3E
 */

/* Oswald font - loaded locally */
@font-face {
	font-family: 'Oswald';
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url('../fonts/Oswald-Regular.woff2') format('woff2');
}

:root {
	--som-bg: #F8F8F5;
	--som-primary: #4C8281;
	--som-primary-dark: #3d6968;
	--som-accent: #C09A52;
	--som-accent-light: #D4AF37;
	--som-text: #2C3E3E;
	--som-text-light: #6B7B7B;
	--som-white: #ffffff;
	--som-shadow: rgba(44, 62, 62, 0.1);
	--container-max: 1200px;
	--spacing: 1.5rem;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	background-color: var(--som-bg);
	color: var(--som-text);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	line-height: 1.6;
	margin: 0;
}

img {
	max-width: 100%;
	height: auto;
}

a {
	color: var(--som-primary);
	text-decoration: none;
}

a:hover {
	color: var(--som-primary-dark);
	text-decoration: underline;
}

.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--spacing);
}

/* Accessibility - Skip link */
.skip-link.screen-reader-text {
	position: absolute;
	left: -9999px;
	top: 0.5rem;
	z-index: 100000;
	padding: 0.75rem 1.25rem;
	background: var(--som-primary);
	color: var(--som-white);
	font-weight: 600;
	text-decoration: none;
	border-radius: 4px;
	transition: left 0.2s;
}
.skip-link.screen-reader-text:focus {
	left: 0.5rem;
}

/* Section dividers */
.section--about::before,
.section--take-action::before,
.section--testimonials::before {
	content: '';
	display: block;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(76, 130, 129, 0.2), transparent);
	margin-bottom: -1px;
}

/* Top Bar */
.top-bar-strip {
	height: 4px;
	background: #1a1a1a;
	width: 100%;
}

.top-bar {
	background: var(--som-primary);
	color: var(--som-white);
	font-size: 0.875rem;
	padding: 0.6rem 0;
}

.top-bar .container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--spacing);
}

.top-bar-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1.5rem;
}

.top-bar-left {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1.25rem;
}

.top-bar-contact-item {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.top-bar-contact-item svg {
	flex-shrink: 0;
	opacity: 0.95;
}

.top-bar-contact-item a {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.top-bar-right {
	text-align: right;
}

.top-bar-contact {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.15rem;
}

.top-bar-info {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.15rem;
}

.top-bar-line {
	margin: 0;
	font-size: 0.8125rem;
	line-height: 1.4;
	color: rgba(255, 255, 255, 0.95);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem;
}

.top-bar-trust-item + .top-bar-trust-item::before {
	content: '•';
	opacity: 0.7;
	margin-right: 0.75rem;
}

.top-bar-trust-item--since {
	font-weight: 600;
}

.top-bar-line--2 {
	font-size: 0.95rem;
	font-weight: 600;
}

.top-bar-phone,
.top-bar-link {
	color: var(--som-white);
	text-decoration: none;
}

.top-bar-phone:hover,
.top-bar-link:hover {
	color: var(--som-accent-light);
}

.top-bar-btn {
	display: inline-block;
	background: var(--som-accent);
	color: var(--som-white);
	padding: 0.5rem 1.25rem;
	border-radius: 6px;
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none;
	transition: background 0.2s, transform 0.15s;
}

.top-bar-btn:hover {
	background: var(--som-accent-light);
	color: var(--som-white);
}

/* Header Branding Strip (Logo + Address) */
.header-branding-strip {
	background: #2d5a5a;
	color: var(--som-white);
	padding: 0.6rem 0;
}

.header-branding-inner {
	display: flex;
	align-items: center;
	gap: 2rem;
}

.header-branding-logo .logo-link,
.header-branding-logo a {
	display: inline-flex;
	align-items: center;
}

.header-branding-logo .logo-link img,
.header-branding-logo .site-logo,
.header-branding-logo .custom-logo {
	width: 80px;
	height: 80px;
	min-width: 80px;
	min-height: 80px;
	border-radius: 50%;
	object-fit: cover;
}

.header-branding-logo .site-name {
	color: var(--som-white);
	font-weight: 700;
	font-size: 1.25rem;
}

.header-branding-info {
	flex: 1;
	min-width: 0;
}

.header-branding-title {
	margin: 0 0 0.05rem 0;
	font-size: 1.3rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	color: var(--som-white);
	line-height: 1.15;
}

.header-branding-address {
	display: flex;
	align-items: flex-start;
	gap: 0.4rem;
	margin: 0;
	font-style: italic;
	font-weight: 700;
	font-size: 0.85rem;
	line-height: 1.05;
	color: rgba(255, 255, 255, 0.95);
}

.header-address-icon {
	flex-shrink: 0;
	margin-top: 0.05em;
}

.header-address-text {
	display: flex;
	flex-direction: column;
	line-height: 1;
}

.header-address-line {
	display: block;
	margin: 0;
	line-height: 1;
}

.header-address-line + .header-address-line {
	margin-top: 0.1em;
}

@media (max-width: 768px) {
	.header-branding-strip {
		position: relative;
	}

	.header-branding-inner {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 1rem;
	}

	.header-branding-info {
		text-align: center;
	}

	.header-branding-address {
		justify-content: center;
	}

	/* Position hamburger on the right so it doesn't affect centered logo */
	.menu-toggle--mobile {
		position: absolute;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
		margin: 0;
	}

	.header-branding-logo .logo-link img,
	.header-branding-logo .site-logo,
	.header-branding-logo .custom-logo {
		width: 66px;
		height: 66px;
		min-width: 66px;
		min-height: 66px;
		border-radius: 50%;
		object-fit: cover;
	}
}

/* Header */
.site-header {
	background: #2d5a5a;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	position: sticky;
	top: 0;
	z-index: 100;
	border-top: 3px solid rgb(255 201 7);
}

.header-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 0;
	gap: 1.5rem;
}

.site-branding {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.logo-link {
	display: inline-flex;
	align-items: center;
	line-height: 1;
}

.logo-link img,
.site-logo {
	max-height: 48px;
	width: auto;
	height: auto;
	object-fit: contain;
	vertical-align: middle;
}

.nav-primary {
	display: flex;
	align-items: center;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.nav-primary li {
	position: relative;
	border-right: 1px solid var(--som-accent-light);
	padding: 0 1.25rem;
}

.nav-primary li:last-child {
	border-right: none;
}

.nav-primary li:first-child {
	padding-left: 1.25rem;
}

.nav-primary a {
	color: rgba(255, 255, 255, 0.95);
	font-weight: 500;
	font-family: 'Oswald', sans-serif;
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	text-decoration: none;
}

.nav-primary a:hover {
	color: var(--som-white);
}

/* Submenu dropdown - desktop */
.site-header {
	overflow: visible;
}

.nav-primary .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	list-style: none;
	margin: 0;
	padding: 0.5rem 0;
	background: #264947;
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
	border-radius: 0 0 6px 6px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px);
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
	z-index: 150;
}

.nav-primary > li:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.nav-primary .sub-menu li {
	border: none;
	padding: 0;
	margin: 0;
}

.nav-primary .sub-menu a {
	display: block;
	padding: 0.65rem 1.25rem;
	color: rgba(255, 255, 255, 0.95);
	font-size: 0.9rem;
	white-space: nowrap;
	transition: background 0.2s ease, color 0.2s ease;
}

.nav-primary .sub-menu a:hover,
.nav-primary .sub-menu a:focus {
	background: var(--som-accent);
	color: var(--som-white);
	border-left: 4px solid var(--som-accent-light);
	padding-left: calc(1.25rem - 4px);
}

.header-actions {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.header-phone {
	color: var(--som-text);
	font-weight: 600;
}

/* Buttons */
.btn {
	display: inline-block;
	padding: 0.6rem 1.5rem;
	font-weight: 600;
	border-radius: 4px;
	text-align: center;
	transition: background 0.2s, color 0.2s;
}

.btn-gold {
	background: var(--som-accent);
	color: var(--som-white);
	border: none;
}

.btn-gold:hover {
	background: var(--som-accent-light);
	color: var(--som-white);
}

.btn--outline {
	background: transparent;
	border: 2px solid var(--som-primary);
	color: var(--som-primary);
}

.btn--outline:hover {
	background: var(--som-primary);
	color: var(--som-white);
}

.btn--primary {
	background: var(--som-primary);
	color: var(--som-white);
	border: none;
}

.btn--primary:hover {
	background: var(--som-primary-dark);
	color: var(--som-white);
}

/* Hero Slider */
.hero-slider {
	position: relative;
	overflow: hidden;
	min-height: 720px;
	animation: heroFadeIn 0.7s ease-out forwards;
}

@keyframes heroFadeIn {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.hero-slider {
		animation: none;
	}
}

.hero-slider__track {
	position: relative;
	min-height: 720px;
}

.hero-slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.6s ease, visibility 0.6s;
	background-size: cover;
	background-position: center;
	background-color: var(--som-primary);
}

.hero-slide.is-active {
	opacity: 1;
	visibility: visible;
	z-index: 1;
}

.hero-slide__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, rgba(44, 62, 62, 0.25), rgba(44, 62, 62, 0.15));
}

.hero-slide__content {
	display: none;
}

.hero-slide__title {
	color: var(--som-white);
	font-size: 2rem;
	line-height: 1.3;
	margin: 0 0 1rem;
}

.hero-slide__desc {
	color: rgba(255, 255, 255, 0.95);
	font-size: 1.1rem;
	margin: 0 0 1.5rem;
}

.hero-slide__cta {
	margin-top: 0.5rem;
}

.hero-slider__nav {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
	display: flex;
	align-items: center;
	gap: 1rem;
}

.hero-slider__dots {
	display: flex;
	gap: 0.5rem;
}

.hero-slider__dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.5);
	border: none;
	cursor: pointer;
	transition: background 0.2s;
}

.hero-slider__dot:hover,
.hero-slider__dot.is-active {
	background: var(--som-accent-light);
}

.hero-slider__prev,
.hero-slider__next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	background: rgba(0, 0, 0, 0.4);
	border: 2px solid rgba(255, 255, 255, 0.6);
	border-radius: 50%;
	color: var(--som-white);
	width: 50px;
	height: 50px;
	cursor: pointer;
	font-size: 1.75rem;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, border-color 0.2s;
}

.hero-slider__prev { left: 1.5rem; }
.hero-slider__next { right: 1.5rem; }

.hero-slider__prev:hover,
.hero-slider__next:hover {
	background: rgba(0, 0, 0, 0.6);
	border-color: var(--som-accent-light);
	color: var(--som-accent-light);
}

/* Welcome Title Section - Typewriter */
.section--welcome-title {
	background: linear-gradient(135deg, #e8f4f4 0%, #f5f0e6 35%, #fef9ed 70%, #e8ebe8 100%);
	padding: 2.5rem 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}

.section--welcome-title::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(120deg, rgba(76, 130, 129, 0.04) 0%, transparent 50%, rgba(192, 154, 82, 0.06) 100%);
	pointer-events: none;
}

.welcome-title-wrapper {
	min-height: 3.5em;
	display: flex;
	align-items: center;
	justify-content: center;
}

.welcome-title {
	font-family: inherit;
	font-size: clamp(1.5rem, 4vw, 2.25rem);
	font-weight: 700;
	color: var(--som-primary);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin: 0;
	display: inline;
}

.welcome-title .welcome-title__typed {
	display: inline;
}

.welcome-title .welcome-title__cursor {
	display: inline-block;
	width: 3px;
	height: 1em;
	background: var(--som-accent);
	vertical-align: -0.1em;
	margin-left: 2px;
	animation: typewriter-blink 0.8s step-end infinite;
}

@keyframes typewriter-blink {
	50% { opacity: 0; }
}

/* Impact Stats Bar */
.section--stats {
	background: linear-gradient(135deg, var(--som-primary) 0%, var(--som-primary-dark) 100%);
	color: var(--som-white);
	padding: 2.5rem 0;
}

.stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	text-align: center;
	max-width: 900px;
	margin: 0 auto;
}

.stats-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.25rem;
}

.stats-item__number {
	font-size: 2.25rem;
	font-weight: 700;
	line-height: 1;
	color: var(--som-accent-light);
	font-family: 'Oswald', sans-serif;
}

.stats-item__label {
	font-size: 0.85rem;
	opacity: 0.95;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

@media (max-width: 768px) {
	.stats-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem;
	}
	.stats-item__number {
		font-size: 1.75rem;
	}
}

/* Scroll-in animations for sections */
.section.scroll-animate {
	opacity: 0;
	transform: translateY(36px);
	transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.section.scroll-animate.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Staggered child animations */
.section.scroll-animate .section-title {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.5s ease 0.1s, transform 0.5s ease 0.1s;
}
.section.scroll-animate.is-visible .section-title {
	opacity: 1;
	transform: translateY(0);
}

.section.scroll-animate .section-subtitle,
.section.scroll-animate .take-action-intro,
.section.scroll-animate .newsletter-intro,
.section.scroll-animate .testimonials-intro,
.section.scroll-animate .success-stories-intro,
.section.scroll-animate .presence-intro__text,
.section.scroll-animate .presence-intro,
.section.scroll-animate .about-tagline {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.45s ease 0.2s, transform 0.45s ease 0.2s;
}
.section.scroll-animate.is-visible .section-subtitle,
.section.scroll-animate.is-visible .take-action-intro,
.section.scroll-animate.is-visible .newsletter-intro,
.section.scroll-animate.is-visible .testimonials-intro,
.section.scroll-animate.is-visible .success-stories-intro,
.section.scroll-animate.is-visible .presence-intro__text,
.section.scroll-animate.is-visible .presence-intro,
.section.scroll-animate.is-visible .about-tagline {
	opacity: 1;
	transform: translateY(0);
}

.section.scroll-animate .stats-item,
.section.scroll-animate .field-item,
.section.scroll-animate .presence-state-card,
.section.scroll-animate .success-story-card,
.section.scroll-animate .testimonial-donor-card,
.section.scroll-animate .award-card,
.section.scroll-animate .campaign-card,
.section.scroll-animate .blog-card {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.5s ease, transform 0.5s ease;
}
.section.scroll-animate.is-visible .stats-item:nth-child(1),
.section.scroll-animate.is-visible .field-item:nth-child(1),
.section.scroll-animate.is-visible .presence-state-card:nth-child(1),
.section.scroll-animate.is-visible .success-story-card:nth-child(1),
.section.scroll-animate.is-visible .testimonial-donor-card:nth-child(1),
.section.scroll-animate.is-visible .award-card:nth-child(1),
.section.scroll-animate.is-visible .campaign-card:nth-child(1),
.section.scroll-animate.is-visible .blog-card:nth-child(1) { opacity: 1; transform: translateY(0); transition-delay: 0.15s; }
.section.scroll-animate.is-visible .stats-item:nth-child(2),
.section.scroll-animate.is-visible .field-item:nth-child(2),
.section.scroll-animate.is-visible .presence-state-card:nth-child(2),
.section.scroll-animate.is-visible .success-story-card:nth-child(2),
.section.scroll-animate.is-visible .testimonial-donor-card:nth-child(2),
.section.scroll-animate.is-visible .award-card:nth-child(2),
.section.scroll-animate.is-visible .campaign-card:nth-child(2),
.section.scroll-animate.is-visible .blog-card:nth-child(2) { opacity: 1; transform: translateY(0); transition-delay: 0.25s; }
.section.scroll-animate.is-visible .stats-item:nth-child(3),
.section.scroll-animate.is-visible .field-item:nth-child(3),
.section.scroll-animate.is-visible .presence-state-card:nth-child(3),
.section.scroll-animate.is-visible .success-story-card:nth-child(3),
.section.scroll-animate.is-visible .testimonial-donor-card:nth-child(3),
.section.scroll-animate.is-visible .award-card:nth-child(3),
.section.scroll-animate.is-visible .campaign-card:nth-child(3),
.section.scroll-animate.is-visible .blog-card:nth-child(3) { opacity: 1; transform: translateY(0); transition-delay: 0.35s; }
.section.scroll-animate.is-visible .stats-item:nth-child(4),
.section.scroll-animate.is-visible .field-item:nth-child(4),
.section.scroll-animate.is-visible .presence-state-card:nth-child(4),
.section.scroll-animate.is-visible .success-story-card:nth-child(4),
.section.scroll-animate.is-visible .testimonial-donor-card:nth-child(4),
.section.scroll-animate.is-visible .award-card:nth-child(4),
.section.scroll-animate.is-visible .campaign-card:nth-child(4),
.section.scroll-animate.is-visible .blog-card:nth-child(4) { opacity: 1; transform: translateY(0); transition-delay: 0.45s; }
.section.scroll-animate.is-visible .stats-item:nth-child(5),
.section.scroll-animate.is-visible .field-item:nth-child(5),
.section.scroll-animate.is-visible .presence-state-card:nth-child(5),
.section.scroll-animate.is-visible .success-story-card:nth-child(5),
.section.scroll-animate.is-visible .award-card:nth-child(5),
.section.scroll-animate.is-visible .campaign-card:nth-child(5),
.section.scroll-animate.is-visible .blog-card:nth-child(5) { opacity: 1; transform: translateY(0); transition-delay: 0.55s; }
.section.scroll-animate.is-visible .stats-item:nth-child(6),
.section.scroll-animate.is-visible .field-item:nth-child(6),
.section.scroll-animate.is-visible .presence-state-card:nth-child(6),
.section.scroll-animate.is-visible .success-story-card:nth-child(6),
.section.scroll-animate.is-visible .testimonial-donor-card:nth-child(6),
.section.scroll-animate.is-visible .award-card:nth-child(6),
.section.scroll-animate.is-visible .campaign-card:nth-child(6),
.section.scroll-animate.is-visible .blog-card:nth-child(6) { opacity: 1; transform: translateY(0); transition-delay: 0.65s; }

.section.scroll-animate.is-visible .take-action-buttons,
.section.scroll-animate.is-visible .newsletter-form,
.section.scroll-animate.is-visible .about-inner,
.section.scroll-animate.is-visible .faq-list {
	opacity: 1;
	transform: translateY(0);
}
.section.scroll-animate .take-action-buttons,
.section.scroll-animate .newsletter-form,
.section.scroll-animate .about-inner,
.section.scroll-animate .faq-list {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.5s ease 0.3s, transform 0.5s ease 0.3s;
}

@media (prefers-reduced-motion: reduce) {
	.section.scroll-animate,
	.section.scroll-animate .section-title,
	.section.scroll-animate .section-subtitle,
	.section.scroll-animate .take-action-intro,
	.section.scroll-animate .newsletter-intro,
	.section.scroll-animate .testimonials-intro,
	.section.scroll-animate .success-stories-intro,
	.section.scroll-animate .presence-intro__text,
	.section.scroll-animate .stats-item,
	.section.scroll-animate .field-item,
	.section.scroll-animate .presence-state-card,
	.section.scroll-animate .success-story-card,
	.section.scroll-animate .testimonial-donor-card,
	.section.scroll-animate .award-card,
	.section.scroll-animate .campaign-card,
	.section.scroll-animate .blog-card,
	.section.scroll-animate .take-action-buttons,
	.section.scroll-animate .newsletter-form,
	.section.scroll-animate .about-inner,
	.section.scroll-animate .faq-list {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* Sections */
.section {
	padding: 4rem 0;
}

/* Section dividers - subtle separator between sections */
.section + .section {
	border-top: 1px solid rgba(76, 130, 129, 0.08);
}

/* Scroll-in animations - each section animates on enter (respects prefers-reduced-motion via JS) */
.section.scroll-animate {
	opacity: 0;
	transform: translateY(32px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.section.scroll-animate.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Staggered child animations - titles and content cascade in */
.section.scroll-animate .section-title,
.section.scroll-animate .section-title--fields,
.section.scroll-animate .section-title--presence,
.section.scroll-animate .section-title--testimonials,
.section.scroll-animate .section-title--take-action,
.section.scroll-animate .section-title--newsletter {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.5s ease 0.1s, transform 0.5s ease 0.1s;
}

.section.scroll-animate.is-visible .section-title,
.section.scroll-animate.is-visible .section-title--fields,
.section.scroll-animate.is-visible .section-title--presence,
.section.scroll-animate.is-visible .section-title--testimonials,
.section.scroll-animate.is-visible .section-title--take-action,
.section.scroll-animate.is-visible .section-title--newsletter {
	opacity: 1;
	transform: translateY(0);
}

.section.scroll-animate .stats-item,
.section.scroll-animate .field-item,
.section.scroll-animate .presence-state-card,
.section.scroll-animate .success-story-card,
.section.scroll-animate .testimonial-donor-card,
.section.scroll-animate .award-card,
.section.scroll-animate .campaign-card,
.section.scroll-animate .blog-card {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.5s ease, transform 0.5s ease;
}

.section.scroll-animate.is-visible .stats-item:nth-child(1) { transition-delay: 0.15s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .stats-item:nth-child(2) { transition-delay: 0.25s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .stats-item:nth-child(3) { transition-delay: 0.35s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .stats-item:nth-child(4) { transition-delay: 0.45s; opacity: 1; transform: translateY(0); }

.section.scroll-animate.is-visible .field-item:nth-child(1) { transition-delay: 0.1s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .field-item:nth-child(2) { transition-delay: 0.2s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .field-item:nth-child(3) { transition-delay: 0.3s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .field-item:nth-child(4) { transition-delay: 0.4s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .field-item:nth-child(5) { transition-delay: 0.5s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .field-item:nth-child(6) { transition-delay: 0.6s; opacity: 1; transform: translateY(0); }

.section.scroll-animate.is-visible .presence-state-card:nth-child(1) { transition-delay: 0.1s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .presence-state-card:nth-child(2) { transition-delay: 0.2s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .presence-state-card:nth-child(3) { transition-delay: 0.3s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .presence-state-card:nth-child(4) { transition-delay: 0.4s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .presence-state-card:nth-child(5) { transition-delay: 0.5s; opacity: 1; transform: translateY(0); }

.section.scroll-animate.is-visible .success-story-card:nth-child(1) { transition-delay: 0.1s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .success-story-card:nth-child(2) { transition-delay: 0.2s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .success-story-card:nth-child(3) { transition-delay: 0.3s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .success-story-card:nth-child(4) { transition-delay: 0.4s; opacity: 1; transform: translateY(0); }

.section.scroll-animate.is-visible .testimonial-donor-card { opacity: 1; transform: translateY(0); }

.section.scroll-animate.is-visible .award-card:nth-child(1) { transition-delay: 0.1s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .award-card:nth-child(2) { transition-delay: 0.2s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .award-card:nth-child(3) { transition-delay: 0.3s; opacity: 1; transform: translateY(0); }

.section.scroll-animate.is-visible .campaign-card:nth-child(1) { transition-delay: 0.1s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .campaign-card:nth-child(2) { transition-delay: 0.2s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .campaign-card:nth-child(3) { transition-delay: 0.3s; opacity: 1; transform: translateY(0); }

.section.scroll-animate.is-visible .blog-card:nth-child(1) { transition-delay: 0.1s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .blog-card:nth-child(2) { transition-delay: 0.2s; opacity: 1; transform: translateY(0); }
.section.scroll-animate.is-visible .blog-card:nth-child(3) { transition-delay: 0.3s; opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
	.section.scroll-animate,
	.section.scroll-animate .section-title,
	.section.scroll-animate .stats-item,
	.section.scroll-animate .field-item,
	.section.scroll-animate .presence-state-card,
	.section.scroll-animate .success-story-card,
	.section.scroll-animate .testimonial-donor-card,
	.section.scroll-animate .award-card,
	.section.scroll-animate .campaign-card,
	.section.scroll-animate .blog-card {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

.section-title {
	color: var(--som-primary);
	font-size: 1.75rem;
	text-align: center;
	margin: 0 0 2rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.section-subtitle {
	text-align: center;
	color: var(--som-text-light);
	max-width: 600px;
	margin: 0 auto 2rem;
}

/* Feature Banner */
.section--feature-banner {
	background: linear-gradient(135deg, var(--som-primary) 0%, var(--som-primary-dark) 100%);
	color: var(--som-white);
	padding: 2.5rem;
}

.section--feature-banner .section-title {
	color: var(--som-white);
	margin-bottom: 0.5rem;
}

.section--feature-banner a {
	color: var(--som-accent-light);
	font-weight: 600;
}

/* About Section */
.section--about {
	background: linear-gradient(180deg, var(--som-white) 0%, var(--som-bg) 100%);
	padding: 4rem 0;
}

.section--about .section-title {
	position: relative;
	padding-bottom: 0.5rem;
	font-size: 1.75rem;
	letter-spacing: 0.02em;
	margin-bottom: 0.5rem;
}

.section--about .section-title::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 60px;
	height: 3px;
	background: var(--som-accent);
	border-radius: 2px;
}

.about-inner {
	display: flex;
	align-items: flex-start;
	gap: 3rem;
}

.about-image {
	flex: 0 0 42%;
	max-width: 42%;
	position: relative;
}

.about-image::before {
	content: '';
	position: absolute;
	top: 12px;
	left: 12px;
	right: -12px;
	bottom: -12px;
	background: linear-gradient(135deg, var(--som-primary) 0%, var(--som-primary-dark) 100%);
	opacity: 0.12;
	border-radius: 12px;
	z-index: -1;
}

.about-image__img {
	width: 100%;
	height: auto;
	border-radius: 10px;
	object-fit: cover;
	box-shadow: 0 8px 24px rgba(44, 62, 62, 0.15);
	border: 3px solid rgba(255, 255, 255, 0.9);
}

.about-content {
	flex: 1;
	min-width: 0;
	padding-left: 1.5rem;
	border-left: 4px solid var(--som-accent);
}

.about-tagline {
	font-size: 1.2rem;
	color: var(--som-primary);
	font-weight: 600;
	margin: 0 0 1.5rem;
	line-height: 1.5;
}

.about-content p {
	margin-bottom: 1.25rem;
	line-height: 1.75;
	color: var(--som-text);
	font-size: 1.05rem;
}

.about-text--short p:last-of-type {
	margin-bottom: 0;
}

.read-more-toggle {
	margin-top: 1.5rem;
	padding: 0.6rem 1.75rem;
	font-weight: 600;
	font-size: 0.95rem;
	transition: all 0.25s ease;
}

.read-more-toggle:hover {
	background: var(--som-primary);
	border-color: var(--som-primary);
	color: var(--som-white);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(76, 130, 129, 0.3);
}

@media (max-width: 900px) {
	.section--about {
		padding: 3rem 0;
	}

	.about-inner {
		flex-direction: column;
		gap: 2rem;
	}

	.about-image {
		flex: none;
		max-width: 100%;
	}

	.about-image::before {
		right: -8px;
		bottom: -8px;
		top: 8px;
		left: 8px;
	}
}

/* Fields of Work - Row layout (icon + label) */
.section--fields-row {
	background: linear-gradient(135deg, #f0fdfa 0%, #fefce8 35%, #fdf4ff 70%, #f0f9ff 100%);
	padding: 4rem 0;
}

.section-title--fields {
	color: var(--som-text);
	font-weight: 700;
	position: relative;
	display: block;
	text-align: center;
}

.section-title--fields::after {
	content: '';
	display: block;
	width: 80px;
	height: 4px;
	background: linear-gradient(90deg, var(--som-primary), var(--som-accent));
	border-radius: 2px;
	margin: 0.5rem auto 0;
}

.fields-row {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: stretch;
	gap: 2rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.field-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	text-decoration: none;
	flex: 1 1 120px;
	min-width: 100px;
	max-width: 180px;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.field-item:hover {
	transform: translateY(-6px);
}

.field-item:hover .field-item__icon {
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
}

.field-item__icon {
	width: 76px;
	height: 76px;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
	transition: box-shadow 0.3s ease;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.field-item__icon svg {
	width: 42px;
	height: 42px;
	fill: currentColor;
}

.field-item__label {
	font-size: 0.875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	transition: color 0.2s ease;
}

/* Vibrant color variants for field icons */
.field-item--teal .field-item__icon { background: linear-gradient(135deg, #0d9488 0%, #14b8a6 100%); color: white; }
.field-item--teal .field-item__label { color: #0f766e; }
.field-item--teal:hover .field-item__label { color: #0d9488; }

.field-item--pink .field-item__icon { background: linear-gradient(135deg, #ec4899 0%, #f472b6 100%); color: white; }
.field-item--pink .field-item__label { color: #be185d; }
.field-item--pink:hover .field-item__label { color: #ec4899; }

.field-item--rose .field-item__icon { background: linear-gradient(135deg, #f43f5e 0%, #fb7185 100%); color: white; }
.field-item--rose .field-item__label { color: #be123c; }
.field-item--rose:hover .field-item__label { color: #f43f5e; }

.field-item--gold .field-item__icon { background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%); color: white; }
.field-item--gold .field-item__label { color: #b45309; }
.field-item--gold:hover .field-item__label { color: #f59e0b; }

.field-item--green .field-item__icon { background: linear-gradient(135deg, #10b981 0%, #34d399 100%); color: white; }
.field-item--green .field-item__label { color: #047857; }
.field-item--green:hover .field-item__label { color: #10b981; }

.field-item--purple .field-item__icon { background: linear-gradient(135deg, #8b5cf6 0%, #a78bfa 100%); color: white; }
.field-item--purple .field-item__label { color: #6d28d9; }
.field-item--purple:hover .field-item__label { color: #8b5cf6; }

@media (max-width: 900px) {
	.fields-row {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 600px) {
	.fields-row {
		grid-template-columns: repeat(2, 1fr);
	}
	.field-item__icon {
		width: 64px;
		height: 64px;
	}
	.field-item__icon svg {
		width: 32px;
		height: 32px;
	}
}

/* Legacy field-card (kept for compatibility) */
.fields-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
}

.field-card {
	background: var(--som-white);
	border-radius: 8px;
	padding: 1.5rem;
	box-shadow: 0 4px 12px var(--som-shadow);
}

/* Presence Section */
.section--presence {
	background: linear-gradient(180deg, #f0fdfa 0%, var(--som-bg) 50%, #fefce8 100%);
	padding: 4rem 0;
}

.section--presence .section-title {
	position: relative;
	display: block;
	text-align: center;
}

.section--presence .section-title::after {
	content: '';
	display: block;
	width: 80px;
	height: 4px;
	background: linear-gradient(90deg, var(--som-primary), var(--som-accent));
	border-radius: 2px;
	margin: 0.5rem auto 1.5rem;
}

.presence-intro {
	margin-bottom: 2.5rem;
}

.presence-intro__text {
	color: var(--som-text);
	line-height: 1.75;
	margin: 0 0 1rem;
	font-size: 1.05rem;
}

.presence-intro__note {
	color: var(--som-text-light);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
	padding-left: 1.25rem;
	border-left: 3px solid var(--som-accent);
}

.presence-states {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.presence-state-card {
	display: flex;
	flex-direction: column;
	background: var(--som-white);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 16px rgba(44, 62, 62, 0.1);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	text-decoration: none;
	color: var(--som-text);
	border: 1px solid rgba(76, 130, 129, 0.08);
}

.presence-state-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 28px rgba(44, 62, 62, 0.15);
}

.presence-state-card__image {
	position: relative;
	display: block;
	width: 100%;
	height: 160px;
	overflow: hidden;
}

.presence-state-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.presence-state-card__icon {
	position: absolute;
	bottom: 12px;
	right: 12px;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--som-white);
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
	color: var(--som-primary);
}

.presence-state-card__icon svg {
	width: 22px;
	height: 22px;
	stroke: currentColor;
}

.presence-state-card__body {
	padding: 1.25rem;
}

.presence-state-card__title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--som-text);
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.presence-state-card--teal { border-top: 4px solid #0d9488; }
.presence-state-card--teal .presence-state-card__title { color: #0d9488; }

.presence-state-card--coral { border-top: 4px solid #e11d48; }
.presence-state-card--coral .presence-state-card__title { color: #e11d48; }

.presence-state-card--green { border-top: 4px solid #047857; }
.presence-state-card--green .presence-state-card__title { color: #047857; }

.presence-state-card--gold { border-top: 4px solid #f59e0b; }
.presence-state-card--gold .presence-state-card__title { color: #b45309; }

.presence-state-card--purple { border-top: 4px solid #8b5cf6; }
.presence-state-card--purple .presence-state-card__title { color: #6d28d9; }

@media (max-width: 900px) {
	.presence-states {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.section--presence {
		padding: 3rem 0;
	}

	.presence-states {
		grid-template-columns: 1fr;
	}

	.presence-state-card__image {
		height: 140px;
	}
}

/* Legacy presence-list (fallback) */
.presence-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

.presence-badge {
	background: var(--som-white);
	border: 2px solid var(--som-primary);
	color: var(--som-primary);
	padding: 0.5rem 1rem;
	border-radius: 4px;
	font-weight: 600;
}

/* Success Stories */
.section--success-stories {
	background: var(--som-bg);
}

.section--success-stories .section-title {
	text-transform: uppercase;
	letter-spacing: 0.03em;
	margin-bottom: 1rem;
}

.success-stories-intro {
	text-align: center;
	max-width: 780px;
	margin: 0 auto 2.5rem;
	color: var(--som-text);
	line-height: 1.7;
	font-size: 1rem;
}

.success-stories-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
	margin-bottom: 2.5rem;
}

.success-story-card {
	background: var(--som-white);
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 4px 16px var(--som-shadow);
	display: flex;
	flex-direction: column;
}

.success-story-card__image {
	display: block;
	position: relative;
	width: 100%;
	height: 200px;
	overflow: hidden;
}

.success-story-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.success-story-card__image--placeholder {
	background: linear-gradient(135deg, var(--som-primary) 0%, var(--som-primary-dark) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}

.success-story-card__placeholder-icon {
	color: var(--som-accent-light);
	font-size: 3rem;
	opacity: 0.8;
}

.success-story-card__body {
	padding: 1.25rem 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.success-story-card__title {
	margin: 0 0 0.75rem;
	font-size: 1.1rem;
	line-height: 1.35;
}

.success-story-card__title a {
	color: var(--som-primary);
}

.success-story-card__title a:hover {
	color: var(--som-primary-dark);
	text-decoration: underline;
}

.success-story-card__excerpt {
	color: var(--som-text);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0 0 1rem;
	flex: 1;
}

.success-story-card__excerpt p {
	margin: 0 0 0.5rem;
}

.success-story-card__excerpt p:last-child {
	margin-bottom: 0;
}

.success-story-card__read-more {
	display: inline-block;
	padding: 0.5rem 1rem;
	background: #9CA3AF;
	color: var(--som-white);
	border-radius: 6px;
	font-size: 0.9rem;
	font-weight: 600;
	transition: background 0.2s;
}

.success-story-card__read-more:hover {
	background: #6B7280;
	color: var(--som-white);
}

.success-stories-cta {
	text-align: center;
}

.success-stories-cta .btn--primary {
	background: var(--som-primary);
	color: var(--som-white);
	padding: 0.75rem 2rem;
	font-size: 1rem;
}

.success-stories-cta .btn--primary:hover {
	background: var(--som-primary-dark);
	color: var(--som-white);
}

/* Legacy story-card (keep for any other use) */
.stories-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
}

.story-card {
	background: var(--som-white);
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 4px 12px var(--som-shadow);
}

.story-card img {
	width: 100%;
	height: 180px;
	object-fit: cover;
}

.story-card-body {
	padding: 1.25rem;
}

.story-card h4 {
	margin: 0 0 0.5rem;
	color: var(--som-primary);
	font-size: 1.1rem;
}

.story-card p {
	margin: 0;
	color: var(--som-text-light);
	font-size: 0.9rem;
}

/* Awards & Recognitions */
.section--awards {
	background: linear-gradient(180deg, var(--som-bg) 0%, var(--som-white) 50%, #fefce8 100%);
	padding: 4rem 0;
}

.section--awards .section-title,
.section--campaigns .section-title,
.section--blog .section-title {
	display: block;
	text-align: center;
}

.section--awards .section-title::after,
.section--campaigns .section-title::after,
.section--blog .section-title::after {
	content: '';
	display: block;
	width: 80px;
	height: 4px;
	background: linear-gradient(90deg, var(--som-primary), var(--som-accent));
	border-radius: 2px;
	margin: 0.5rem auto 2rem;
}

.awards-intro {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 2rem;
	color: var(--som-text);
	line-height: 1.75;
	font-size: 1.05rem;
}

.awards-content {
	display: flex;
	justify-content: center;
}

.awards-placeholder-card {
	background: var(--som-white);
	border-radius: 16px;
	padding: 3rem 2.5rem;
	text-align: center;
	box-shadow: 0 8px 32px rgba(44, 62, 62, 0.08);
	border: 1px solid rgba(76, 130, 129, 0.08);
	max-width: 520px;
}

.awards-placeholder-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--som-accent) 0%, var(--som-accent-light) 100%);
	color: var(--som-white);
	margin-bottom: 1.5rem;
}

.awards-placeholder-icon svg {
	width: 40px;
	height: 40px;
}

.awards-placeholder-text {
	margin: 0;
	color: var(--som-text-light);
	font-size: 1rem;
	line-height: 1.6;
}

/* Campaigns */
.section--campaigns {
	background: var(--som-white);
	padding: 4rem 0;
}

.campaigns-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 1.5rem;
}

.campaign-card {
	background: var(--som-white);
	border-radius: 16px;
	padding: 2rem 1.75rem;
	box-shadow: 0 4px 24px rgba(44, 62, 62, 0.08);
	border: 1px solid rgba(76, 130, 129, 0.08);
	position: relative;
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.campaign-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(44, 62, 62, 0.12);
}

.campaign-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: 14px;
	margin-bottom: 1.25rem;
	color: var(--som-white);
}

.campaign-card--teal .campaign-card__icon { background: linear-gradient(135deg, #0d9488 0%, #14b8a6 100%); }
.campaign-card--rose .campaign-card__icon { background: linear-gradient(135deg, #f43f5e 0%, #fb7185 100%); }
.campaign-card--gold .campaign-card__icon { background: linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%); }

.campaign-card__icon svg {
	width: 28px;
	height: 28px;
	stroke: currentColor;
}

.campaign-card__category {
	display: inline-block;
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--som-primary);
	margin-bottom: 0.5rem;
}

.campaign-card__title {
	color: var(--som-text);
	margin: 0 0 1rem;
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1.3;
}

.campaign-card__desc {
	color: var(--som-text-light);
	margin: 0 0 1.5rem;
	font-size: 0.95rem;
	line-height: 1.65;
}

.campaign-card__cta {
	display: inline-block;
	padding: 0.6rem 1.5rem;
	font-size: 0.9rem;
	font-weight: 600;
	border-radius: 8px;
	transition: all 0.25s ease;
}

.campaign-card__cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(76, 130, 129, 0.3);
}

/* Blog / News & Updates */
.section--blog {
	background: linear-gradient(180deg, #f0fdfa 0%, var(--som-bg) 100%);
	padding: 4rem 0;
}

.blog-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
}

.blog-card {
	background: var(--som-white);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(44, 62, 62, 0.08);
	display: flex;
	flex-direction: column;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.blog-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 36px rgba(44, 62, 62, 0.12);
}

.blog-card__image {
	display: block;
	width: 100%;
	height: 200px;
	overflow: hidden;
}

.blog-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.blog-card:hover .blog-card__image img {
	transform: scale(1.05);
}

.blog-card__image--placeholder {
	background: linear-gradient(135deg, var(--som-primary) 0%, var(--som-primary-dark) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.7);
}

.blog-card__image--placeholder svg {
	width: 48px;
	height: 48px;
}

.blog-card__body {
	padding: 1.5rem 1.75rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.blog-card__title {
	margin: 0 0 0.75rem;
	font-size: 1.15rem;
	line-height: 1.35;
	font-weight: 700;
}

.blog-card__title a {
	color: var(--som-text);
	text-decoration: none;
}

.blog-card__title a:hover {
	color: var(--som-primary);
}

.blog-card__excerpt {
	color: var(--som-text-light);
	font-size: 0.95rem;
	line-height: 1.65;
	margin: 0 0 1rem;
	flex: 1;
}

.blog-card__excerpt p {
	margin: 0 0 0.5rem;
}

.blog-card__excerpt p:last-child {
	margin-bottom: 0;
}

.blog-card__link {
	display: inline-block;
	font-weight: 600;
	color: var(--som-primary);
	font-size: 0.95rem;
	transition: color 0.2s;
}

.blog-card__link:hover {
	color: var(--som-primary-dark);
}

/* Blog carousel - scrollable news & updates */
.blog-carousel {
	position: relative;
	max-width: 520px;
	margin: 0 auto;
}
.blog-carousel__viewport {
	overflow: hidden;
}
.blog-carousel__track {
	display: flex;
	transition: transform 0.4s ease;
}
.blog-carousel__slide {
	flex: 0 0 100%;
	min-width: 0;
	padding: 0 0.5rem;
	box-sizing: border-box;
}
.blog-carousel .blog-card {
	max-width: 100%;
}
.blog-carousel__prev,
.blog-carousel__next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--som-primary);
	color: var(--som-white);
	border: none;
	cursor: pointer;
	font-size: 1.25rem;
	line-height: 1;
	transition: background 0.2s;
	z-index: 2;
}
.blog-carousel__prev { left: -1rem; }
.blog-carousel__next { right: -1rem; }
.blog-carousel__prev:hover,
.blog-carousel__next:hover {
	background: var(--som-primary-dark);
}
.blog-carousel__dots {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 1.5rem;
	flex-wrap: wrap;
}
.blog-carousel__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: none;
	background: rgba(76, 130, 129, 0.3);
	cursor: pointer;
	transition: background 0.2s;
}
.blog-carousel__dot.is-active {
	background: var(--som-primary);
}
@media (min-width: 768px) {
	.blog-carousel {
		max-width: 600px;
	}
}
@media (max-width: 768px) {
	.blog-carousel__prev { left: 0.5rem; }
	.blog-carousel__next { right: 0.5rem; }
}

/* Newsletter */
.section--newsletter {
	background: linear-gradient(135deg, #f0fdfa 0%, #fefce8 50%, #fdf4ff 100%);
	padding: 4rem 0;
}

.section--newsletter .section-title--newsletter {
	text-align: center;
	margin-bottom: 0.5rem;
}

.section--newsletter .section-title--newsletter::after {
	content: '';
	display: block;
	width: 60px;
	height: 3px;
	background: linear-gradient(90deg, var(--som-primary), var(--som-accent));
	margin: 0.5rem auto 1rem;
	border-radius: 2px;
}

.newsletter-inner {
	max-width: 560px;
	margin: 0 auto;
	text-align: center;
}

.newsletter-intro {
	margin: 0 0 1.5rem;
	color: var(--som-text-light);
	font-size: 1rem;
	line-height: 1.6;
}

.newsletter-form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: center;
	align-items: stretch;
}

.newsletter-form__input {
	flex: 1;
	min-width: 200px;
	padding: 0.65rem 1rem;
	border: 2px solid var(--som-primary);
	border-radius: 6px;
	font-size: 1rem;
	background: var(--som-white);
}

.newsletter-form__input:focus {
	outline: none;
	border-color: var(--som-accent);
	box-shadow: 0 0 0 3px rgba(76, 130, 129, 0.2);
}

.newsletter-form__btn {
	background: var(--som-primary);
	color: var(--som-white);
	border: none;
	padding: 0.65rem 1.5rem;
	border-radius: 6px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s;
}

.newsletter-form__btn:hover {
	background: var(--som-primary-dark);
	color: var(--som-white);
}

.newsletter-success {
	margin: 1rem 0 0;
	color: var(--som-primary);
	font-weight: 600;
}

/* Take Action */
.section--take-action {
	background: linear-gradient(135deg, var(--som-primary) 0%, var(--som-primary-dark) 100%);
	color: var(--som-white);
	padding: 4rem 0;
}

.section--take-action .section-title {
	color: var(--som-white);
	display: block;
	text-align: center;
}

.section--take-action .section-title::after {
	content: '';
	display: block;
	width: 80px;
	height: 4px;
	background: linear-gradient(90deg, var(--som-accent-light), var(--som-accent));
	border-radius: 2px;
	margin: 0.5rem auto 1.5rem;
}

.take-action-intro {
	text-align: center;
	max-width: 580px;
	margin: 0 auto 2rem;
	font-size: 1.1rem;
	line-height: 1.65;
	opacity: 0.95;
}

.take-action-buttons {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1.25rem;
}

.take-action-btn {
	padding: 0.85rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	border-radius: 10px;
	transition: all 0.25s ease;
}

.take-action-buttons .btn-gold {
	background: var(--som-accent);
	color: var(--som-white);
	border: none;
}

.take-action-buttons .btn-gold:hover {
	background: var(--som-accent-light);
	color: var(--som-white);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(192, 154, 82, 0.4);
}

.take-action-btn--outline {
	background: transparent;
	border: 2px solid rgba(255, 255, 255, 0.9);
	color: var(--som-white);
}

.take-action-btn--outline:hover {
	background: rgba(255, 255, 255, 0.15);
	border-color: var(--som-white);
	color: var(--som-white);
	transform: translateY(-2px);
}

@media (max-width: 600px) {
	.campaigns-grid {
		grid-template-columns: 1fr;
	}

	.blog-grid {
		grid-template-columns: 1fr;
	}

	.take-action-buttons {
		flex-direction: column;
	}

	.take-action-btn {
		width: 100%;
		text-align: center;
	}
}

/* Testimonials */
.testimonials-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
}

.testimonial-card {
	background: var(--som-white);
	padding: 1.5rem;
	border-radius: 8px;
	box-shadow: 0 4px 12px var(--som-shadow);
	border-left: 4px solid var(--som-accent);
}

.testimonial-card blockquote {
	margin: 0 0 1rem;
	font-style: italic;
	color: var(--som-text);
}

.testimonial-card cite {
	color: var(--som-text-light);
	font-size: 0.9rem;
}

/* Donor Testimonials (What Donor Says) */
.section--testimonials {
	background: var(--som-bg);
}

.section-title--testimonials {
	color: var(--som-accent);
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.testimonials-intro {
	text-align: center;
	max-width: 780px;
	margin: 0 auto 2.5rem;
	color: var(--som-text);
	line-height: 1.7;
	font-size: 1rem;
}

/* Testimonials Carousel */
.testimonials-carousel {
	position: relative;
	max-width: 700px;
	margin: 0 auto;
}
.testimonials-carousel__viewport {
	overflow: hidden;
}
.testimonials-carousel__track {
	display: flex;
	transition: transform 0.4s ease;
}
.testimonials-carousel__slide {
	flex: 0 0 100%;
	min-width: 0;
	padding: 0 0.5rem;
}
.testimonials-carousel__prev,
.testimonials-carousel__next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--som-primary);
	color: var(--som-white);
	border: none;
	cursor: pointer;
	font-size: 1.25rem;
	transition: background 0.2s;
}
.testimonials-carousel__prev { left: -1rem; }
.testimonials-carousel__next { right: -1rem; }
.testimonials-carousel__prev:hover,
.testimonials-carousel__next:hover {
	background: var(--som-primary-dark);
}
.testimonials-carousel__dots {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 1.5rem;
}
.testimonials-carousel__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: none;
	background: rgba(76, 130, 129, 0.3);
	cursor: pointer;
	transition: background 0.2s;
}
.testimonials-carousel__dot.is-active {
	background: var(--som-primary);
}
@media (max-width: 768px) {
	.testimonials-carousel__prev { left: 0.5rem; }
	.testimonials-carousel__next { right: 0.5rem; }
}

/* Testimonials Carousel */
.testimonials-carousel {
	position: relative;
	max-width: 700px;
	margin: 0 auto;
}

.testimonials-carousel__viewport {
	overflow: hidden;
}

.testimonials-carousel__track {
	display: flex;
	transition: transform 0.4s ease;
}

.testimonials-carousel__slide {
	flex: 0 0 100%;
	min-width: 100%;
	padding: 0 0.5rem;
}

.testimonials-carousel__prev,
.testimonials-carousel__next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--som-white);
	border: 2px solid var(--som-primary);
	color: var(--som-primary);
	cursor: pointer;
	font-size: 1.25rem;
	line-height: 1;
	transition: background 0.2s, color 0.2s;
	z-index: 2;
}

.testimonials-carousel__prev { left: -1rem; }
.testimonials-carousel__next { right: -1rem; }

.testimonials-carousel__prev:hover,
.testimonials-carousel__next:hover {
	background: var(--som-primary);
	color: var(--som-white);
}

.testimonials-carousel__dots {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 1.5rem;
}

.testimonials-carousel__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(76, 130, 129, 0.4);
	border: none;
	cursor: pointer;
	transition: background 0.2s;
}

.testimonials-carousel__dot.is-active {
	background: var(--som-primary);
}

.testimonials-grid--donors {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	max-width: 1000px;
	margin: 0 auto;
}

.testimonial-donor-card {
	background: var(--som-white);
	border-radius: 12px;
	padding: 2rem 2rem 2.5rem;
	box-shadow: 0 4px 20px var(--som-shadow);
	position: relative;
	text-align: center;
}

.testimonial-donor-card__quote-open,
.testimonial-donor-card__quote-close {
	position: absolute;
	font-size: 4rem;
	line-height: 1;
	color: var(--som-text);
	opacity: 0.15;
	font-family: Georgia, serif;
}

.testimonial-donor-card__quote-open {
	top: 0.5rem;
	left: 1rem;
}

.testimonial-donor-card__quote-close {
	bottom: 0.5rem;
	right: 1rem;
}

.testimonial-donor-card__avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	overflow: hidden;
	margin: 0 auto 1rem;
}

.testimonial-donor-card__avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.testimonial-donor-card__avatar--placeholder {
	background: linear-gradient(135deg, var(--som-primary) 0%, var(--som-primary-dark) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
}

.testimonial-donor-card__avatar-initial {
	color: var(--som-white);
	font-size: 2rem;
	font-weight: 700;
}

.testimonial-donor-card__stars {
	margin-bottom: 1rem;
}

.testimonial-donor-card__star {
	color: var(--som-text-light);
	font-size: 1.25rem;
}

.testimonial-donor-card__star.filled {
	color: var(--som-accent);
}

.testimonial-donor-card__quote {
	margin: 0 0 1.25rem;
	color: var(--som-text);
	font-size: 0.95rem;
	line-height: 1.7;
	font-style: normal;
}

.testimonial-donor-card__quote p {
	margin: 0 0 0.5rem;
}

.testimonial-donor-card__quote p:last-child {
	margin-bottom: 0;
}

.testimonial-donor-card__footer {
	margin-top: auto;
}

.testimonial-donor-card__author {
	display: block;
	font-style: normal;
	font-weight: 700;
	color: var(--som-text);
	font-size: 1rem;
}

.testimonial-donor-card__location {
	display: block;
	color: var(--som-text-light);
	font-size: 0.9rem;
	margin-top: 0.25rem;
}

@media (max-width: 768px) {
	.testimonials-grid--donors {
		grid-template-columns: 1fr;
	}
}

/* FAQ Section - decorative background with question mark motif */
.section--faq {
	position: relative;
	background-color: var(--som-white);
	background-image:
		/* Dotted grid + crosshatch pattern */
		radial-gradient(circle at center, rgba(76, 130, 129, 0.08) 1.5px, transparent 1.5px),
		repeating-linear-gradient(
			45deg,
			transparent,
			transparent 18px,
			rgba(76, 130, 129, 0.06) 18px,
			rgba(76, 130, 129, 0.06) 20px
		),
		repeating-linear-gradient(
			-45deg,
			transparent,
			transparent 18px,
			rgba(76, 130, 129, 0.05) 18px,
			rgba(76, 130, 129, 0.05) 20px
		);
	background-size:
		24px 24px,
		40px 40px,
		40px 40px;
	border-bottom: 4px solid #c62828;
	overflow: hidden;
}

.section--faq::before {
	content: "?";
	position: absolute;
	left: -0.05em;
	bottom: 0;
	font-size: clamp(8rem, 25vw, 18rem);
	font-weight: 700;
	color: transparent;
	-webkit-text-stroke: 3px #c62828;
	line-height: 0.85;
	pointer-events: none;
	opacity: 0.92;
	z-index: 0;
}

.section--faq::after {
	content: "???";
	position: absolute;
	top: 1rem;
	right: 1.5rem;
	font-size: 2.5rem;
	font-weight: 700;
	color: rgba(0, 0, 0, 0.07);
	letter-spacing: 0.15em;
	pointer-events: none;
	z-index: 0;
}

.section--faq .container {
	position: relative;
	z-index: 1;
}

/* FAQ Accordion */
.faq-list {
	max-width: 700px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
}

.faq-item {
	background: var(--som-white);
	margin-bottom: 0.5rem;
	border-radius: 4px;
	box-shadow: 0 2px 8px var(--som-shadow);
	overflow: hidden;
}

.faq-question {
	width: 100%;
	padding: 1rem 1.25rem;
	text-align: left;
	background: none;
	border: none;
	font-weight: 600;
	color: var(--som-text);
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.faq-question:hover {
	color: var(--som-primary);
}

.faq-question::after {
	content: "+";
	font-size: 1.25rem;
	color: var(--som-primary);
}

.faq-item.active .faq-question::after {
	content: "−";
}

.faq-answer {
	padding: 0 1.25rem 1rem;
	display: none;
}

.faq-item.active .faq-answer {
	display: block;
}

.faq-answer p {
	margin: 0;
	color: var(--som-text-light);
}

/* Footer */
.site-footer {
	background: var(--som-primary);
	color: var(--som-white);
	padding: 3rem 0 1.5rem;
}

.footer-main {
	margin-bottom: 2rem;
}

.footer-grid,
.footer-inner {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 2rem;
}

.footer-col h4,
.footer-block h4 {
	color: var(--som-accent-light);
	font-size: 1rem;
	margin: 0 0 1rem;
}

.footer-col p,
.footer-col address,
.footer-block p,
.footer-block address {
	margin: 0;
	font-size: 0.9rem;
	opacity: 0.95;
}

.footer-col a,
.footer-block a {
	color: var(--som-white);
}

.footer-col a:hover,
.footer-block a:hover {
	color: var(--som-accent-light);
}

.footer-logo {
	max-height: 80px;
	width: auto;
}

.footer-tagline {
	margin: 0.5rem 0 0;
	font-size: 0.9rem;
	opacity: 0.9;
}

.footer-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-menu li {
	margin-bottom: 0.5rem;
}

.footer-bottom {
	text-align: center;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
	font-size: 0.875rem;
	opacity: 0.9;
}

.footer-powered,
.footer-powered-by {
	color: inherit;
}

.footer-bottom .footer-powered__link,
.footer-bottom .footer-powered a,
.footer-powered-by a {
	color: #D4AF37 !important;
	font-weight: 600;
	text-decoration: none;
	transition: color 0.2s;
}

.footer-bottom .footer-powered__link:hover,
.footer-bottom .footer-powered a:hover,
.footer-powered-by a:hover {
	color: #C09A52 !important;
}

.footer-bottom .footer-visitors {
	display: block;
	margin-top: 1rem;
	padding-top: 0.75rem;
	border-top: 1px solid rgba(255, 255, 255, 0.15);
	opacity: 0.95;
}

.footer-nav {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

.footer-nav a {
	color: var(--som-white);
}

.site-name {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--som-primary);
}

/* Floating CTA - Support Us */
.floating-cta {
	position: fixed;
	bottom: 1.5rem;
	left: 1.5rem;
	padding: 0.5rem 1.25rem;
	background: var(--som-accent);
	color: var(--som-white) !important;
	font-weight: 600;
	font-size: 0.9rem;
	border-radius: 9999px;
	text-decoration: none !important;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, background 0.2s;
	z-index: 998;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.floating-cta.visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.floating-cta:hover {
	background: var(--som-accent-light);
	color: var(--som-white) !important;
}

@media (max-width: 600px) {
	.floating-cta { left: 1rem; bottom: 1rem; font-size: 0.85rem; padding: 0.4rem 1rem; }
	.back-to-top { bottom: 1rem; right: 1rem; width: 44px; height: 44px; }
}

/* Floating Support Us CTA */
.floating-cta {
	position: fixed;
	bottom: 1.5rem;
	left: 1.5rem;
	padding: 0.6rem 1.25rem;
	border-radius: 2rem;
	background: var(--som-accent);
	color: var(--som-white) !important;
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, background 0.2s;
	z-index: 998;
}

.floating-cta.visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.floating-cta:hover {
	background: var(--som-accent-light);
	color: var(--som-white) !important;
}

@media (max-width: 480px) {
	.floating-cta {
		bottom: 5rem;
		left: 1rem;
		font-size: 0.85rem;
		padding: 0.5rem 1rem;
	}
}

/* Floating CTA (Support Us) */
.floating-cta {
	position: fixed;
	bottom: 1.5rem;
	left: 1.5rem;
	padding: 0.6rem 1.25rem;
	border-radius: 2rem;
	background: var(--som-accent);
	color: var(--som-white) !important;
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, background 0.2s;
	z-index: 998;
}

.floating-cta.visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.floating-cta:hover {
	background: var(--som-accent-light);
	color: var(--som-white) !important;
}

@media (max-width: 600px) {
	.floating-cta {
		bottom: 5.5rem;
		left: 1rem;
		font-size: 0.85rem;
		padding: 0.5rem 1rem;
	}
}

/* Floating Support Us CTA */
.floating-cta {
	position: fixed;
	bottom: 1.5rem;
	left: 1.5rem;
	padding: 0.6rem 1.25rem;
	border-radius: 50px;
	background: var(--som-accent);
	color: var(--som-white) !important;
	font-weight: 600;
	text-decoration: none !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	opacity: 0;
	visibility: hidden;
	transform: translateX(-10px);
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, background 0.2s;
	z-index: 998;
}

.floating-cta.visible {
	opacity: 1;
	visibility: visible;
	transform: translateX(0);
}

.floating-cta:hover {
	background: var(--som-accent-light);
	color: var(--som-white) !important;
}

@media (max-width: 480px) {
	.floating-cta { left: 1rem; bottom: 1rem; font-size: 0.9rem; padding: 0.5rem 1rem; }
	.back-to-top { bottom: 1rem; right: 1rem; }
}

/* Floating Support Us CTA */
.floating-cta {
	position: fixed;
	bottom: 1.5rem;
	left: 1.5rem;
	padding: 0.6rem 1.25rem;
	border-radius: 50px;
	background: var(--som-accent);
	color: var(--som-white) !important;
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, background 0.2s;
	z-index: 998;
}

.floating-cta.visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.floating-cta:hover {
	background: var(--som-accent-light);
	color: var(--som-white) !important;
}

@media (max-width: 600px) {
	.floating-cta { bottom: 5rem; left: 1rem; }
	.back-to-top { bottom: 1rem; right: 1rem; }
}

/* Back to top button */
.back-to-top {
	position: fixed;
	bottom: 1.5rem;
	right: 1.5rem;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--som-primary);
	color: var(--som-white);
	border: 2px solid var(--som-accent-light);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: opacity 0.3s, visibility 0.3s, transform 0.3s, background 0.2s;
	z-index: 999;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.back-to-top.visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.back-to-top:hover {
	background: var(--som-primary-dark);
	color: var(--som-accent-light);
}

.btn-donate,
.btn-donate-top {
	background: var(--som-accent);
	color: var(--som-white);
	padding: 0.4rem 1rem;
	border-radius: 4px;
	font-weight: 600;
}

.btn-donate:hover,
.btn-donate-top:hover {
	background: var(--som-accent-light);
	color: var(--som-white);
}

/* Page Templates */
.page-title {
	color: var(--som-primary);
	text-align: center;
	margin: 0 0 2rem;
}

.contact-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 2rem;
}

.contact-block {
	background: var(--som-white);
	padding: 1.5rem;
	border-radius: 8px;
	box-shadow: 0 4px 12px var(--som-shadow);
}

.contact-block h3 {
	color: var(--som-primary);
	margin: 0 0 0.5rem;
}

.donate-cta {
	text-align: center;
	margin-top: 2rem;
	padding: 2rem;
	background: var(--som-white);
	border-radius: 8px;
}

/* Mobile Menu */
.main-navigation {
	position: relative;
}

.menu-toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.5rem;
	font-size: 1.5rem;
	color: rgba(255, 255, 255, 0.95);
	line-height: 1;
}

.menu-toggle-bar {
	display: block;
	width: 24px;
	height: 2px;
	background: currentColor;
	margin: 5px 0;
	transition: transform 0.2s;
}

.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(2) {
	opacity: 0;
}

.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 1024px) {
	.success-stories-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.success-stories-grid {
		grid-template-columns: 1fr;
	}
}

/* Tablet: switch to mobile menu for cleaner layout */
@media (max-width: 992px) {
	.menu-toggle {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		min-width: 44px;
		min-height: 44px;
	}

	/* Ensure branding strip has positioning context for absolute toggle */
	.header-branding-strip {
		position: relative;
		padding-right: 3rem;
	}

	/* Mobile toggle in branding strip: visible, positioned top-right */
	.header-branding-strip .menu-toggle--mobile {
		position: absolute;
		right: 0.5rem;
		top: 50%;
		transform: translateY(-50%);
		z-index: 10;
	}

	.header-inner {
		justify-content: space-between;
		position: relative;
	}

	.main-navigation {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		width: 100%;
		z-index: 200;
	}

	.nav-primary {
		position: relative;
		top: auto;
		left: auto;
		right: auto;
		background: var(--som-white);
		flex-direction: column;
		padding: 1rem;
		box-shadow: 0 4px 12px var(--som-shadow);
		display: none;
	}

	.nav-primary.active {
		display: flex;
	}

	.nav-primary li {
		border-right: none;
		border-bottom: 1px solid rgba(0, 0, 0, 0.08);
		padding: 0.75rem 0;
	}

	.nav-primary li:last-child {
		border-bottom: none;
	}

	.nav-primary li:first-child {
		padding-left: 0;
	}

	.nav-primary a {
		color: var(--som-text);
		display: block;
		padding: 0.25rem 0;
	}

	.nav-primary a:hover {
		color: var(--som-primary);
	}

	/* Mobile submenu: show inline with indent and background */
	.nav-primary .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		background: rgba(76, 130, 129, 0.08);
		border-radius: 6px;
		margin: 0.5rem 0 0.75rem 0;
		padding: 0.5rem 0;
		min-width: auto;
	}

	.nav-primary .sub-menu li {
		border-bottom: 1px solid rgba(0, 0, 0, 0.05);
	}

	.nav-primary .sub-menu li:last-child {
		border-bottom: none;
	}

	.nav-primary .sub-menu a {
		color: var(--som-text);
		padding: 0.5rem 1rem 0.5rem 1.25rem;
	}

	.nav-primary .sub-menu a:hover,
	.nav-primary .sub-menu a:focus {
		background: rgba(76, 130, 129, 0.15);
		color: var(--som-primary);
	}
}

/* Mobile: same as tablet, ensure full-width dropdown */
@media (max-width: 768px) {
	.testimonials-grid--donors {
		grid-template-columns: 1fr;
	}

	.hero-slide h2 {
		font-size: 1.5rem;
	}

	.hero-slide-content {
		padding: 3rem 1rem;
	}
}
