/* =============================================================================
   CSFWR Theme — Custom Styles
   ============================================================================= */

/* ── CSS Custom Properties ─────────────────────────────────────────────────── */

:root {
	--csfwr-primary-dark:   #1b2a3d;
	--csfwr-navy:           #1e3a5f;
	--csfwr-navy-dark:      #0f1b2e;
	--csfwr-accent-red:     #c41230;
	--csfwr-accent-red-h:   #a30f28;
	--csfwr-white:          #ffffff;
	--csfwr-light-gray:     #f4f6f8;
	--csfwr-border:         #e5e7eb;
	--csfwr-text:           #1a1a1a;
	--csfwr-muted:          #6b7280;
	--csfwr-shadow-sm:      0 1px 3px rgba(0,0,0,0.10);
	--csfwr-shadow-md:      0 4px 12px rgba(0,0,0,0.12);
	--csfwr-shadow-lg:      0 8px 24px rgba(0,0,0,0.15);
	--csfwr-radius:         4px;
	--csfwr-radius-sm:      2px;
	--csfwr-transition:     all 0.2s ease;
	--csfwr-max-width:      1200px;
	--csfwr-content-pad:    clamp(1rem, 4vw, 2rem);
}

/* ── Base Reset / Global ────────────────────────────────────────────────────── */

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: clip;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
	font-family: var(--wp--preset--font-family--heading);
}

h1 { font-size: 3.75rem;  font-weight: 700; line-height: 1.15; }
h2 { font-size: 2.25rem;  font-weight: 700; line-height: 1.2;  }
h3 { font-size: 1.875rem; font-weight: 700; line-height: 1.3;  }
h4 { font-size: 1.125rem; font-weight: 600; line-height: 1.4;  }
h5 { font-size: 1rem;     font-weight: 600; line-height: 1.5;  }
h6 { font-size: 0.875rem; font-weight: 600; line-height: 1.5;  }

/* ── Page content paragraphs ────────────────────────────────────────────────── */

.wp-block-post-content p {
	font-size: 1.0625rem;
	line-height: 1.75;
	color: #374151;
	margin-top: 0;
	margin-bottom: 1rem;
}

/* ── Page content components (principles cards, what-we-do items, standards) ── */

/* Section intro header group: h2 + subtitle p before a columns row */
.wp-block-post-content .wp-block-group:has(+ .wp-block-columns) h2.wp-block-heading {
	text-align: center;
	margin-bottom: 0.4rem !important;
}
.wp-block-post-content .wp-block-group:has(+ .wp-block-columns) p {
	text-align: center;
	color: var(--csfwr-muted);
	font-size: 1rem;
	margin-bottom: 1.75rem;
}

/* Sections that need wider than the default 960px content width */
.wp-block-post-content > .principles-section,
.wp-block-post-content > *:has(.impact-cards-grid) {
	max-width: 1100px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Principles section: full-bleed gray background via pseudo-element */
.principles-section {
	position: relative;
	padding-top: 2.5rem;
	padding-bottom: 2.5rem;
	margin-top: 2rem;
	margin-bottom: 2rem;
	background-color: transparent;
}
.principles-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100vw;
	height: 100%;
	background-color: var(--csfwr-light-gray);
	z-index: -1;
}

/* Principle card: bordered white box */
.wp-block-post-content .wp-block-column > .wp-block-group:has(.wp-block-column > svg) {
	border: 1px solid var(--csfwr-border);
	padding: 1.25rem;
	background-color: #fff;
	height: 100%;
}

/* Principle card: inner columns row — icon left, text right */
.wp-block-post-content .wp-block-column > .wp-block-group:has(.wp-block-column > svg) > .wp-block-columns {
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: flex-start !important;
	gap: 1rem !important;
}

/* Principle card: shrink icon column to fit SVG */
.wp-block-post-content .wp-block-column:has(> svg) {
	flex: 0 0 auto !important;
	width: auto !important;
}

/* Principle card: dark navy icon box */
.wp-block-post-content .wp-block-column:has(> svg) > svg {
	display: block;
	width: 3rem;
	height: 3rem;
	padding: 0.5rem;
	background-color: var(--csfwr-navy);
	color: #fff;
	flex-shrink: 0;
}

/* Principle card: heading and paragraph */
.wp-block-post-content .wp-block-column > .wp-block-group:has(.wp-block-column > svg) h2.wp-block-heading {
	font-size: 1.25rem !important;
	font-weight: 600 !important;
	margin-top: 0 !important;
	margin-bottom: 0.75rem !important;
	padding-bottom: 0 !important;
	color: var(--csfwr-navy) !important;
}
.wp-block-post-content .wp-block-column > .wp-block-group:has(.wp-block-column > svg) p {
	font-size: 0.9375rem;
	color: var(--csfwr-muted);
	margin-bottom: 0;
}

/* "What We Do" items */
.what-we-do-item {
	border-left: 4px solid var(--csfwr-accent-red);
	padding-left: 1rem;
	margin-bottom: 1.5rem;
}
.what-we-do-item h2.wp-block-heading {
	font-size: 1.25rem !important;
	font-weight: 600;
	margin-top: 0 !important;
	margin-bottom: 0.75rem !important;
	padding-bottom: 0 !important;
	color: var(--csfwr-navy) !important;
}
.what-we-do-item p {
	font-size: 0.9375rem;
	color: var(--csfwr-muted);
	margin-bottom: 0;
}

/* Standards section: full-bleed beige background via pseudo-element */
.standards-section {
	position: relative;
	padding-top: 2.5rem;
	padding-bottom: 2.5rem;
	margin-top: 2rem;
	margin-bottom: 2rem;
	background-color: transparent;
}
.standards-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100vw;
	height: 100%;
	background-color: #fdf9f5;
	z-index: -1;
}

/* "Our Standards" list: white card with red circle-check bullets */
.wp-block-post-content .wp-block-list {
	list-style: none !important;
	padding: 1.5rem 1.75rem !important;
	background-color: #fff;
	border: 1px solid #f0e5d8;
	border-radius: 6px;
	margin-bottom: 2rem;
}
.wp-block-post-content .wp-block-list li {
	padding-left: 2rem;
	position: relative;
	margin-bottom: 0.75rem;
	font-size: 0.9375rem;
	line-height: 1.65;
	color: #374151;
}
.wp-block-post-content .wp-block-list li:last-child {
	margin-bottom: 0;
}
.wp-block-post-content .wp-block-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.15rem;
	width: 1.125rem;
	height: 1.125rem;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c41230' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpath d='m9 12 2 2 4-4'%3E%3C/path%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
}

/* ── Section heading accent (red left border) ───────────────────────────────── */

.section-heading-accent {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	font-size: 2.25rem !important;
	color: var(--csfwr-navy-dark) !important;
	line-height: 40px !important;
	position: relative;
	padding-left: 1.125rem !important;
	border-left: 4px solid var(--csfwr-accent-red) !important;
	margin-bottom: 0.25rem !important;
}

/* ── Page content h2 headings ──────────────────────────────────────────────── */

.wp-block-post-content h2.wp-block-heading {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	font-weight: 700;
	color: var(--csfwr-primary-dark);
	line-height: 1.25;
	margin-top: 2.5rem;
	margin-bottom: 0.5rem;
}

/* Red left-border heading — add class "section-heading-ruled" to any Heading block */
h2.section-heading-ruled,
h3.section-heading-ruled {
	border-left: 4px solid var(--csfwr-accent-red);
	padding-left: 0.875rem !important;
	margin-bottom: 0.35rem !important;
}

/* Red rule separator — add a Separator block with class "red-rule" after any h2 that needs the underline */
hr.red-rule,
.wp-block-separator.red-rule {
	border: none !important;
	background-color: var(--csfwr-accent-red) !important;
	color: var(--csfwr-accent-red) !important;
	height: 3px !important;
	width: 2.5rem !important;
	max-width: 2.5rem !important;
	margin-top: 0 !important;
	margin-bottom: 1.25rem !important;
	margin-left: 0 !important;
	margin-right: auto !important;
	border-radius: 2px !important;
	align-self: flex-start !important;
}

/* ── Site Header ────────────────────────────────────────────────────────────── */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	border-bottom: 4px solid var(--csfwr-accent-red);
}

.site-header.wp-block-group.has-background {
	padding: 0.5rem !important;
}

.header-inner {
	padding-top: 0.5rem !important;
	padding-bottom: 0.5rem !important;
	padding-left: var(--csfwr-content-pad) !important;
	padding-right: var(--csfwr-content-pad) !important;
	max-width: var(--csfwr-max-width);
	margin-left: auto;
	margin-right: auto;
}

/* Logo area */
.site-logo-area {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration: none;
	flex-shrink: 0;
}

.site-logo-img {
	height: 80px;
	width: auto;
	display: block;
}

.wy-badge {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	background-color: var(--csfwr-accent-red);
	color: #fff;
	font-family: var(--wp--preset--font-family--heading, Georgia, serif);
	font-size: 1.05rem;
	font-weight: 800;
	letter-spacing: -0.02em;
	border-radius: 3px;
	flex-shrink: 0;
}

.site-name-group {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.site-name-group .site-name {
	color: #fff;
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.3;
	margin: 0;
}

.site-name-group .site-sub {
	color: rgba(255,255,255,0.55);
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin: 0;
}

/* Header navigation */
.header-nav-group {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.site-header .wp-block-navigation {
	color: rgba(255,255,255,0.88);
}

.site-header .wp-block-navigation a {
	color: rgba(255,255,255,0.88);
	font-size: 0.875rem;
	font-weight: 500;
	padding: 0.375rem 0.625rem;
	border-radius: var(--csfwr-radius);
	transition: var(--csfwr-transition);
	text-decoration: none;
}

.site-header .wp-block-navigation a:hover,
.site-header .wp-block-navigation a:focus {
	color: #fff;
	background-color: rgba(255,255,255,0.1);
}

.site-header .wp-block-navigation .current-menu-item > a {
	color: #fff;
}

/* Classic menu rendered via [csfwr_primary_nav] shortcode */
.csfwr-site-nav {
	display: flex;
	align-items: center;
}

.csfwr-nav-list {
	display: flex;
	align-items: center;
	gap: 0.125rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.csfwr-nav-list li {
	position: relative;
	margin-right: 1rem;
}

.csfwr-nav-list a {
	display: block;
	color: var(--csfwr-navy-dark);
	font-family: var(--wp--preset--font-family--ui, sans-serif);
	font-size: 1rem;
	font-weight: 500;
	padding: 0.375rem 1rem;
	border-radius: 2px;
	text-decoration: none;
	white-space: nowrap;
	transition: color 0.2s ease;
	position: relative;
}

.csfwr-nav-list a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 1rem;
	right: 1rem;
	height: 2px;
	background-color: var(--csfwr-accent-red);
	transform: scaleX(0);
	transition: transform 0.2s ease;
	transform-origin: left;
}

.csfwr-nav-list a:hover,
.csfwr-nav-list a:focus {
	color: var(--csfwr-accent-red);
	background-color: transparent;
}

.csfwr-nav-list a:hover::after,
.csfwr-nav-list a:focus::after {
	transform: scaleX(1);
}

.csfwr-nav-list .current-menu-item > a,
.csfwr-nav-list .current_page_item > a {
	background-color: var(--csfwr-accent-red) !important;
	color: #fff !important;
	border-radius: 2px;
}

/* Dropdown sub-menus */
.csfwr-nav-list .sub-menu {
	display: none;
	position: absolute;
	top: calc(100% + 4px);
	left: 0;
	min-width: 200px;
	background-color: var(--csfwr-primary-dark);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: var(--csfwr-radius);
	list-style: none;
	padding: 0.375rem 0;
	margin: 0;
	box-shadow: var(--csfwr-shadow-lg);
	z-index: 200;
}

.csfwr-nav-list li:hover > .sub-menu,
.csfwr-nav-list li:focus-within > .sub-menu {
	display: block;
}

.csfwr-nav-list .sub-menu a {
	padding: 0.5rem 1rem;
	border-radius: 0;
	font-size: 0.85rem;
}

/* Header CTA buttons */
.header-nav-group .wp-block-buttons {
	gap: 1rem;
}

.header-btn-outline .wp-block-button__link {
	background-color: var(--csfwr-navy) !important;
	color: #fff !important;
	border: 2px solid var(--csfwr-navy) !important;
	padding: 0.45rem 1rem !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	border-radius: 2px !important;
	transition: var(--csfwr-transition) !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.35rem !important;
}

.header-btn-outline .wp-block-button__link:hover {
	background-color: #fff !important;
	color: var(--csfwr-navy) !important;
	border-color: var(--csfwr-navy) !important;
}

.header-btn-donate .wp-block-button__link {
	background-color: var(--csfwr-accent-red) !important;
	color: #fff !important;
	border: 2px solid var(--csfwr-accent-red) !important;
	padding: 0.45rem 1rem !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	border-radius: 2px !important;
	transition: var(--csfwr-transition) !important;
}

.header-btn-donate .wp-block-button__link:hover {
	background-color: #fff !important;
	color: var(--csfwr-accent-red) !important;
	border-color: var(--csfwr-accent-red) !important;
}

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

.home-hero {
	background-image: url('/wp-content/themes/csfwr/assets/images/tetons_bg.jpg');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	position: relative;
	overflow: hidden;
	border-bottom: 0.5rem solid var(--csfwr-accent-red);
}

/* Dark overlay sits between the background image and the content */
.home-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(10, 40, 100, 0.82);
	pointer-events: none;
	z-index: 0;
}

/* Ensure hero content renders above the overlay */
.home-hero .hero-inner {
	position: relative;
	z-index: 1;
}

.hero-inner {
	padding-top: 4rem !important;
	padding-bottom: 4rem !important;
	padding-left: var(--csfwr-content-pad) !important;
	padding-right: var(--csfwr-content-pad) !important;
	max-width: var(--csfwr-max-width);
	margin: 0 auto;
}

.hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background-color: transparent;
	color: var(--csfwr-accent-red);
	border: 1.5px solid var(--csfwr-accent-red);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 0.4rem 1rem;
	border-radius: 999px;
	margin-bottom: 1.5rem;
}

.home-hero,
.home-hero .hero-inner,
.home-hero .hero-inner * {
	text-align: left !important;
}

.home-hero .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)),
.home-hero .hero-inner > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.hero-heading {
	color: #fff !important;
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	font-size: 4.5rem !important;
	font-weight: 700 !important;
	line-height: 1.1 !important;
	text-align: left !important;
	max-width: 56rem !important;
	margin-top: 0 !important;
	margin-bottom: 1.25rem !important;
}

.hero-subtext {
	color: #fff !important;
	font-size: 1.5rem !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
	max-width: 56rem !important;
	margin-top: 0 !important;
	margin-bottom: 0.75rem !important;
}

.hero-footnote {
	color: rgba(255,255,255,0.85) !important;
	font-size: 1.125rem !important;
	line-height: 1.6 !important;
	max-width: 56rem !important;
	margin-top: 0 !important;
	margin-bottom: 2.5rem !important;
}

.hero-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.875rem;
	margin-top: 2rem;
}

.hero-btn-outline .wp-block-button__link {
	background-color: var(--csfwr-accent-red) !important;
	color: #fff !important;
	border: 2px solid var(--csfwr-accent-red) !important;
	padding: 0.75rem 1.5rem !important;
	font-weight: 600 !important;
	font-size: 1.15rem !important;
	border-radius: var(--csfwr-radius) !important;
	transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.4rem !important;
}

.hero-btn-outline .wp-block-button__link:hover {
	transform: scale(1.05) !important;
}

.hero-btn-donate .wp-block-button__link {
	background-color: transparent !important;
	color: #fff !important;
	border: 2px solid #fff !important;
	padding: 0.75rem 1.5rem !important;
	font-weight: 600 !important;
	font-size: 1.15rem !important;
	border-radius: var(--csfwr-radius) !important;
	transition: transform 0.2s ease, background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.4rem !important;
}

.hero-btn-donate .wp-block-button__link:hover {
	background-color: #fff !important;
	color: var(--csfwr-navy-dark) !important;
	border-color: #fff !important;
	transform: scale(1.05) !important;
}

/* ── Featured Response Section ──────────────────────────────────────────────── */

.section-featured-response {
	padding-top: 4rem;
	padding-bottom: 4rem;
}

.featured-response-card {
	border: 2px solid var(--csfwr-border);
	border-radius: 0;
	overflow: hidden;
	box-shadow: var(--csfwr-shadow-sm);
	position: relative;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.featured-response-card:hover {
	border-color: var(--csfwr-accent-red);
	box-shadow: var(--csfwr-shadow-md);
}

.featured-response-card .wp-block-post-featured-image img,
.featured-response-card .wp-block-post-featured-image a {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.featured-response-card .wp-block-post-featured-image {
	height: 100%;
	min-height: 200px;
	overflow: hidden;
}

.featured-response-card .wp-block-post-featured-image img {
	transition: transform 0.4s ease;
}

.featured-response-card:hover .wp-block-post-featured-image img {
	transform: scale(1.05);
}

.featured-card-content {
	padding: 1.5rem;
}

/* Category badge overlaid on featured image */
.featured-image-col {
	position: relative;
}

.featured-image-badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
	margin: 0 !important;
}

/* Category badge in featured card */
.featured-image-badge a,
.featured-card-content .wp-block-post-terms a {
	display: inline-block;
	font-family: var(--wp--preset--font-family--ui, sans-serif);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.3rem 0.7rem;
	background-color: #2e5080;
	color: #fff;
	border-radius: var(--csfwr-radius-sm);
	text-decoration: none;
	margin-bottom: 0.875rem;
}

.featured-card-content .wp-block-post-title {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	font-size: 2.25rem !important;
	line-height: 1.15 !important;
	letter-spacing: -0.02em !important;
	margin-bottom: 0.875rem;
}

.featured-card-content .wp-block-post-title a {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: var(--csfwr-navy-dark) !important;
	text-decoration: none;
	transition: color 0.2s;
}

.featured-card-content .wp-block-post-title a:hover {
	color: inherit;
}

.featured-card-content .wp-block-post-excerpt {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: #2d3748 !important;
	font-size: 1.25rem !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
	margin-bottom: 1.25rem;
}

.featured-card-summary {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: #374151 !important;
	font-size: 1rem !important;
	line-height: 1.7 !important;
	margin-bottom: 1.25rem;
}

.featured-card-meta {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	color: var(--csfwr-muted);
	font-size: 0.8rem;
	margin-bottom: 1.25rem;
}

.featured-card-author svg,
.featured-card-date svg {
	color: var(--csfwr-muted);
	flex-shrink: 0;
}

.featured-card-meta .wp-block-post-author-name a,
.featured-card-meta .wp-block-post-author-name {
	color: var(--csfwr-muted);
	text-decoration: none;
	font-weight: 500 !important;
	font-size: 0.9rem !important;
}

.featured-card-meta .wp-block-post-date a,
.featured-card-meta .wp-block-post-date {
	color: var(--csfwr-muted);
	text-decoration: none;
	font-size: 0.9rem !important;
}

.featured-card-meta .wp-block-read-more {
	color: var(--csfwr-accent-red) !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	text-decoration: none;
	white-space: nowrap;
	z-index: 2;
	position: relative;
}

.featured-read-more {
	transition: transform 0.25s ease;
}

.featured-response-card:hover .featured-read-more {
	transform: translateX(1rem);
}

.featured-read-more svg {
	color: var(--csfwr-accent-red);
	flex-shrink: 0;
	z-index: 2;
	position: relative;
}

/* Stretch title link to cover entire card */
.featured-card-content .wp-block-post-title a::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
}

.read-more-link .wp-block-read-more {
	display: inline-flex;
	align-items: center;
	color: var(--csfwr-accent-red);
	font-weight: 600;
	font-size: 0.875rem;
	text-decoration: none;
	white-space: nowrap;
	transition: opacity 0.2s;
}

.read-more-link .wp-block-read-more:hover {
	opacity: 0.8;
}

/* ── Explore by Topic Section ───────────────────────────────────────────────── */

.section-explore-topics {
	background-color: var(--csfwr-light-gray);
	padding-top: 3.5rem;
	padding-bottom: 3.5rem;
}

.topic-card {
	background-color: #fff;
	border: 1px solid var(--csfwr-border);
	border-radius: 6px;
	padding: 1.75rem 1.5rem;
	text-align: center;
	transition: border-color 0.25s ease;
	text-decoration: none;
	display: block;
	box-shadow: var(--csfwr-shadow-sm);
	position: relative;
	overflow: hidden;
}

/* Animated red top border */
.topic-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	height: 3px;
	width: 0;
	background-color: var(--csfwr-accent-red);
	transition: width 0.3s ease;
}

/* Arrow slides in from the right */
.topic-card-arrow {
	position: absolute;
	top: 0.75rem;
	right: -2rem;
	color: var(--csfwr-accent-red);
	transition: right 0.3s ease;
}

.topic-card:hover {
	border-color: var(--csfwr-accent-red);
	text-decoration: none;
}

.topic-card:hover::before {
	width: 100%;
}

.topic-card:hover .topic-card-arrow {
	right: 0.75rem;
}

.topic-card-icon {
	width: 44px;
	height: 44px;
	margin: 0 auto 1rem;
	color: var(--csfwr-accent-red);
}

.topic-card-icon svg {
	width: 100%;
	height: 100%;
}

.topic-card-title {
	font-weight: 700;
	font-size: 1.125rem;
	color: var(--csfwr-text);
	margin-bottom: 0.25rem;
}

.topic-card-desc {
	font-size: 0.8rem;
	color: var(--csfwr-muted);
}

/* ── Latest Articles Section ────────────────────────────────────────────────── */

.section-latest-articles {
	padding-top: 4rem;
	padding-bottom: 4rem;
}

/* Article cards */
.article-card {
	border: 2px solid var(--csfwr-border);
	border-radius: 0;
	overflow: hidden;
	background: #fff;
	box-shadow: var(--csfwr-shadow-sm);
	transition: border-color 0.2s ease;
	display: flex;
	flex-direction: column;
	height: 100%;
	position: relative;
}

.article-card:hover {
	border-color: var(--csfwr-accent-red);
}

.article-card .wp-block-post-featured-image {
	position: relative;
	overflow: hidden;
}

.article-card .wp-block-post-featured-image img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.article-card:hover .wp-block-post-featured-image img {
	transform: scale(1.03);
}

.article-card .wp-block-post-featured-image a {
	display: block;
}

.article-card__content {
	padding: 1.25rem !important;
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* Category badge — overlaid on image */
.article-card__image-wrap {
	position: relative;
}

.article-card__badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
	margin: 0 !important;
}

.article-card__badge a {
	display: inline-block;
	font-family: var(--wp--preset--font-family--ui, sans-serif);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.3rem 0.7rem;
	text-decoration: none;
	color: #fff;
	background-color: var(--csfwr-primary-dark);
}

/* Category-specific badge colors */
.article-card__badge a[href*="fact-check"],
.article-card__badge a[href*="fact-checks"] {
	background-color: #1e6fad;
}

.article-card__badge a[href*="policy"],
.article-card__badge a[href*="policies"] {
	background-color: #0f7566;
}

.article-card__badge a[href*="response"],
.article-card__badge a[href*="responses"] {
	background-color: #c05621;
}

.article-card__badge a[href*="analysis"],
.article-card__badge a[href*="analyses"] {
	background-color: #4a3f6b;
}

/* Overlay category badge on image */
.card-image-wrap {
	position: relative;
}

.card-category-overlay {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	z-index: 2;
}

.category-badge {
	display: inline-block;
	font-family: var(--wp--preset--font-family--ui, sans-serif);
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.3rem 0.7rem;
	border-radius: var(--csfwr-radius-sm);
	text-decoration: none;
	color: #fff;
	line-height: 1.4;
}

.category-badge--fact-check   { background-color: #1e6fad; }
.category-badge--policy       { background-color: #0f7566; }
.category-badge--response     { background-color: #c05621; }
.category-badge--analysis     { background-color: #4a3f6b; }
.category-badge--default      { background-color: var(--csfwr-primary-dark); }

.article-title {
	font-size: clamp(1rem, 1.5vw, 1.125rem);
	line-height: 1.3;
	margin-bottom: 0.5rem;
	flex: 1;
}

.article-card .wp-block-post-title {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	font-size: 1.25rem !important;
	line-height: 1.35;
	margin-bottom: 0.5rem;
}

.article-card .wp-block-post-title a {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: var(--csfwr-text);
	text-decoration: none;
}

.article-card .wp-block-post-title a::after {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 1;
}

/* Ensure interactive elements stay above the stretched link */
.article-card .wp-block-read-more {
	position: relative;
	z-index: 2;
}

.article-excerpt {
	color: var(--csfwr-muted);
	font-size: 0.85rem;
	line-height: 1.6;
	margin-bottom: 1rem;
	flex: 1;
}

.article-card__summary {
	color: #374151 !important;
	font-size: 0.875rem !important;
	line-height: 1.6 !important;
	margin-bottom: 0.875rem;
}

.article-meta {
	display: flex;
	align-items: center;
	gap: 1rem;
	color: var(--csfwr-muted);
	font-size: 0.75rem;
	margin-top: auto;
	padding-top: 0.75rem;
	border-top: 1px solid var(--csfwr-border);
}

.article-meta .wp-block-post-author-name,
.article-meta .wp-block-post-author-name a {
	color: var(--csfwr-muted);
	text-decoration: none;
	font-weight: 500;
}

.article-meta .wp-block-post-date,
.article-meta .wp-block-post-date a {
	color: var(--csfwr-muted);
	text-decoration: none;
}

/* Author / date sub-groups */
.article-meta__author,
.article-meta__date {
	gap: 0.3rem;
	color: var(--csfwr-muted);
	font-size: 0.75rem;
}

.article-meta > .wp-block-group {
	gap: 0.75rem;
}

/* Red arrow on right */
.article-meta__arrow {
	color: var(--csfwr-accent-red);
	flex-shrink: 0;
	transition: transform 0.2s ease;
}

.article-card:hover .article-meta__arrow {
	transform: translateX(0.375rem);
}

/* Arrow link on cards */
.article-arrow-link {
	display: inline-flex;
	align-items: center;
	color: var(--csfwr-accent-red);
	font-size: 1rem;
	text-decoration: none;
	transition: transform 0.2s;
}

.article-arrow-link:hover {
	transform: translateX(3px);
}

/* Query loop grid */
.wp-block-query .wp-block-post-template {
	gap: 1.5rem !important;
}

/* ── Support CTA Section ────────────────────────────────────────────────────── */

.section-support-cta {
	background: linear-gradient(135deg, #1b2a3d 0%, #243448 100%);
	padding: 5rem 2rem;
	text-align: center;
}

/* Full-width breakout when used inside page.html's padded content group */
.wp-block-post-content .section-support-cta {
	width: 100vw !important;
	max-width: 100vw !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
	margin-top: clamp(3rem, 8vw, 100px) !important;
}

.section-support-cta .support-heading {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	font-size: 3rem !important;
	color: #fff;
	margin-bottom: 1rem;
}

.section-support-cta .support-text {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: rgba(255,255,255,0.8);
	font-size: 1.5rem !important;
	line-height: 1.5 !important;
	margin: 0 auto 2.5rem;
}

/* Get Involved — red filled (matches hero) */
.cta-btn-outline .wp-block-button__link {
	background-color: var(--csfwr-accent-red) !important;
	color: #fff !important;
	border: 2px solid var(--csfwr-accent-red) !important;
	padding: 0.75rem 1.5rem !important;
	font-weight: 600 !important;
	font-size: 1.15rem !important;
	border-radius: var(--csfwr-radius) !important;
	transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.4rem !important;
	text-decoration: none !important;
}

.cta-btn-outline .wp-block-button__link:hover {
	transform: scale(1.05) !important;
}

/* Donate Now — transparent white outline (matches hero) */
.cta-btn-donate .wp-block-button__link {
	background-color: transparent !important;
	color: #fff !important;
	border: 2px solid #fff !important;
	padding: 0.75rem 1.5rem !important;
	font-weight: 600 !important;
	font-size: 1.15rem !important;
	border-radius: var(--csfwr-radius) !important;
	transition: transform 0.2s ease, background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.4rem !important;
	text-decoration: none !important;
}

.cta-btn-donate .wp-block-button__link:hover {
	background-color: #fff !important;
	color: var(--csfwr-navy-dark) !important;
	border-color: #fff !important;
	transform: scale(1.05) !important;
}

/* ── Stay Informed / Newsletter Section ─────────────────────────────────────── */

.section-newsletter {
	padding: 4rem 2rem;
	background-color: var(--csfwr-light-gray);
}

.newsletter-card {
	max-width: 832px;
	margin: 0 auto;
	border: 2px solid var(--csfwr-primary-dark);
	border-radius: 8px;
	padding: 2rem 3rem;
	position: relative;
	text-align: center;
	background: #fff;
	overflow: hidden;
}

/* Decorative corner accent — soft pink circle */
.newsletter-card::after {
	content: '';
	position: absolute;
	top: -40px;
	right: -40px;
	width: 120px;
	height: 120px;
	background: rgba(196, 18, 48, 0.08);
	border-radius: 50%;
}

.newsletter-icon {
	width: 56px;
	height: 56px;
	margin: 0 auto 1.25rem;
	background-color: var(--csfwr-primary-dark);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}

.newsletter-icon svg {
	width: 26px;
	height: 26px;
}

.newsletter-heading {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--csfwr-primary-dark);
	margin-bottom: 0.625rem;
}

.newsletter-text {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: var(--csfwr-muted);
	font-size: 0.9rem;
	margin-bottom: 1.5rem;
}

.newsletter-form-wrap {
	display: flex;
	gap: 0.5rem;
	max-width: 500px;
	margin: 0 auto;
}

.newsletter-form-wrap input[type="email"] {
	flex: 1;
	padding: 0.7rem 1rem;
	border: 1px solid var(--csfwr-border);
	border-radius: var(--csfwr-radius);
	font-size: 0.875rem;
	font-family: inherit;
	outline: none;
	transition: border-color 0.2s;
}

.newsletter-form-wrap input[type="email"]:focus {
	border-color: var(--csfwr-accent-red);
}

.newsletter-form-wrap input[type="email"]::placeholder {
	color: #aaa;
}

.newsletter-form-wrap .newsletter-submit {
	background-color: var(--csfwr-accent-red);
	color: #fff;
	border: none;
	padding: 0.7rem 1.25rem;
	border-radius: var(--csfwr-radius);
	font-size: 0.875rem;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
	transition: background-color 0.2s;
	white-space: nowrap;
}

.newsletter-form-wrap .newsletter-submit:hover {
	background-color: var(--csfwr-accent-red-h);
}

.newsletter-privacy {
	color: #aaa;
	font-size: 0.75rem;
	margin-top: 0.875rem;
}

/* ── Values Banner Section ──────────────────────────────────────────────────── */

.section-values-banner {
	background-image: url('/wp-content/themes/csfwr/assets/images/tetons_bg.jpg');
	background-size: cover;
	background-position: center;
	min-height: 320px;
	padding: 2rem;
	text-align: center;
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.section-values-banner::before {
	content: '';
	position: absolute;
	inset: 0;
	background-color: rgba(10, 40, 100, 0.82);
	pointer-events: none;
}

.values-banner-inner {
	position: relative;
	z-index: 1;
	width: 100%;
}

.values-heading {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: #fff !important;
	font-size: 3rem !important;
	line-height: 1.15 !important;
	margin-bottom: 1rem;
}

.values-subtext {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: rgba(255,255,255,0.8) !important;
	font-size: 1.25rem !important;
}

/* post-title and post-excerpt inside the values banner (page.html) */
.section-values-banner .wp-block-post-title {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: #fff !important;
	font-size: 3rem !important;
	line-height: 1.15 !important;
	text-align: center !important;
	margin-bottom: 1rem !important;
}

.section-values-banner .wp-block-post-excerpt {
	text-align: center !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	padding: 0 !important;
}

.section-values-banner .wp-block-post-excerpt__excerpt {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: rgba(255,255,255,0.8) !important;
	font-size: 1.25rem !important;
	text-align: center !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* ── Site Footer ────────────────────────────────────────────────────────────── */

.site-footer {
	background-color: var(--csfwr-primary-dark);
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	margin-top: 5rem;
}

.footer-main {
	padding: 3.5rem var(--csfwr-content-pad) 2rem;
	max-width: var(--csfwr-max-width);
	margin: 0 auto;
}

.footer-brand p {
	color: rgba(255,255,255,0.65);
	font-size: 0.85rem;
	line-height: 1.7;
	margin-top: 0.875rem;
}

.footer-brand .site-logo-area {
	margin-bottom: 0.75rem;
}

/* Footer social icons */
.footer-follow-label {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	color: rgba(255,255,255,0.6);
	margin: 1.25rem 0 0.5rem;
}

.footer-social {
	display: flex;
	gap: 0.75rem;
	margin-top: 0;
}

.footer-social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background-color: rgba(255,255,255,0.1);
	color: rgba(255,255,255,0.8);
	transition: var(--csfwr-transition);
	text-decoration: none;
}

.footer-social a:hover {
	background-color: var(--csfwr-accent-red);
	color: #fff;
}

.footer-social svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

/* Footer nav columns */
.footer-nav-col h4 {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: #fff;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-bottom: 1rem;
}

.footer-nav-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.footer-nav-col ul li {
	margin-bottom: 0.5rem;
}

.footer-nav-col ul li a {
	color: #fff;
	font-size: 0.875rem;
	text-decoration: none;
	transition: color 0.2s;
}

.footer-nav-col ul li a:hover {
	color: var(--csfwr-accent-red);
}

.site-footer .wp-block-navigation a,
.site-footer .wp-block-navigation-item__content {
	color: #fff !important;
	font-size: 0.875rem;
	text-decoration: none;
	transition: color 0.2s;
}

.site-footer .wp-block-navigation a:hover,
.site-footer .wp-block-navigation-item__content:hover {
	color: var(--csfwr-accent-red) !important;
}

/* Footer bottom bar */
.footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.1);
	padding: 1.25rem var(--csfwr-content-pad);
	max-width: var(--csfwr-max-width);
	margin: 0 auto;
}

.footer-bottom .wp-block-columns {
	align-items: center;
	margin-bottom: 0;
}

.footer-bottom .wp-block-column {
	margin-bottom: 0;
}

.footer-copyright {
	color: #9ca3af !important;
	font-size: 0.8rem;
}

/* ── Single Post Page ───────────────────────────────────────────────────────── */

.single-post-content {
	max-width: 760px;
	margin: 0 auto;
	padding: 3rem var(--csfwr-content-pad) 4rem;
}

.single-post-header {
	margin-bottom: 2rem;
}

.post-category-badge {
	display: inline-block;
	font-family: var(--wp--preset--font-family--ui, sans-serif);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.3rem 0.75rem;
	background-color: var(--csfwr-primary-dark);
	color: #fff;
	border-radius: var(--csfwr-radius-sm);
	text-decoration: none;
	margin-bottom: 1rem;
}

.single-post-meta {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	color: var(--csfwr-muted);
	font-size: 0.85rem;
	margin-top: 1rem;
}

/* ── Topics Page Header ─────────────────────────────────────────────────────── */

.topics-page-header .wp-block-query-title,
.topics-page-header .wp-block-post-title {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	color: #fff !important;
	margin-bottom: 0.5rem !important;
}

.topics-page-header .wp-block-term-description,
.topics-page-header .wp-block-post-excerpt,
.topics-page-header .wp-block-post-excerpt__excerpt {
	color: rgba(255,255,255,0.7) !important;
	font-size: 1rem !important;
}

.topics-page-header .wp-block-post-excerpt {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	padding: 0 !important;
}

.topics-page-header .wp-block-post-excerpt__excerpt {
	margin: 0 !important;
	padding: 0 !important;
}

/* Archive title with category icon */
.topics-page-header .wp-block-query-title {
	display: flex;
	align-items: center;
	gap: 0.6rem;
}

.archive-title-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	padding: 0.5rem;
	background-color: var(--csfwr-navy);
	border-radius: var(--csfwr-radius);
	color: #fff;
}

.archive-title-icon svg {
	width: 1.5rem;
	height: 1.5rem;
}

/* ── Topics Filter Tabs ─────────────────────────────────────────────────────── */

.topics-filter-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 2rem;
	padding-bottom: 1.75rem;
	border-bottom: 1px solid var(--csfwr-border);
}

.tab-btn {
	display: inline-block;
	padding: 0.45rem 1.125rem;
	font-size: 0.875rem;
	font-weight: 600;
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	border: 1.5px solid var(--csfwr-border);
	border-radius: 2px;
	color: var(--csfwr-text);
	background-color: #fff;
	text-decoration: none;
	transition: var(--csfwr-transition);
	white-space: nowrap;
	line-height: 1.5;
}

.tab-btn:hover {
	border-color: var(--csfwr-primary-dark);
	color: var(--csfwr-primary-dark);
	text-decoration: none;
}

.tab-btn--active,
.tab-btn--active:hover {
	background-color: var(--csfwr-primary-dark);
	border-color: var(--csfwr-primary-dark);
	color: #fff;
}

/* ── Archive / Blog Index ───────────────────────────────────────────────────── */

.archive-header {
	background-color: var(--csfwr-primary-dark);
	padding: 3rem var(--csfwr-content-pad);
	text-align: center;
}

.archive-header h1 {
	color: #fff;
	font-size: clamp(1.75rem, 3vw, 2.5rem);
}

.archive-description {
	color: rgba(255,255,255,0.72);
	font-size: 1rem;
	margin-top: 0.5rem;
}

/* ── Pagination ─────────────────────────────────────────────────────────────── */

.wp-block-query-pagination {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 3rem;
}

.wp-block-query-pagination .page-numbers,
.wp-block-query-pagination-next a,
.wp-block-query-pagination-previous a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 0.75rem;
	border: 1px solid var(--csfwr-border);
	border-radius: var(--csfwr-radius);
	color: var(--csfwr-text);
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 500;
	transition: var(--csfwr-transition);
}

.wp-block-query-pagination .page-numbers:hover,
.wp-block-query-pagination-next a:hover,
.wp-block-query-pagination-previous a:hover {
	background-color: var(--csfwr-accent-red);
	border-color: var(--csfwr-accent-red);
	color: #fff;
}

.wp-block-query-pagination .page-numbers.current {
	background-color: var(--csfwr-accent-red);
	border-color: var(--csfwr-accent-red);
	color: #fff;
}

/* ── Get Involved Page ───────────────────────────────────────────────────────── */

/* Grid: override constrained layout and set 3-col CSS grid */
.impact-cards-grid.wp-block-group {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	max-width: 1100px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	padding: 0 !important;
}

/* Remove max-width constrained layout applies to direct children (grid → cards) */
.impact-cards-grid.wp-block-group > .wp-block-group {
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* Card */
.impact-card {
	background-color: var(--csfwr-white);
	border: 3px solid var(--csfwr-border);
	border-radius: 0;
	padding: 1.5rem !important;
	min-height: 280px;
	position: relative;
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.impact-card:hover {
	border-color: var(--csfwr-accent-red);
	box-shadow: var(--csfwr-shadow-md);
}

/* Stretched link — CTA anchor covers entire card */
.impact-card p:last-child a::after {
	content: '';
	position: absolute;
	inset: 0;
}

/* Override constrained layout centering on card's direct children */
.impact-card > * {
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	width: 100%;
}

/* Icon — Custom HTML block renders SVG directly without a wrapper div on the frontend */
.impact-card svg {
	display: block;
	width: 48px;
	height: 48px;
	padding: 0.625rem;
	background-color: var(--csfwr-navy);
	color: #fff;
	stroke: #fff;
	border-radius: var(--csfwr-radius);
	flex-shrink: 0;
	margin-bottom: 1rem;
}

/* Accent card (Support Our Mission) — red icon */
.impact-card--accent svg {
	background-color: var(--csfwr-accent-red);
}

/* Card heading */
.impact-card .wp-block-heading {
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: 1.5rem !important;
	font-weight: 700 !important;
	color: var(--csfwr-primary-dark) !important;
	margin-top: 0 !important;
	margin-bottom: 0.5rem !important;
	line-height: 1.3 !important;
}

/* Body copy */
.impact-card p:not(:last-child) {
	font-size: 0.9375rem;
	color: var(--csfwr-muted);
	line-height: 1.65;
	flex-grow: 1;
	margin-bottom: 1.25rem !important;
}

/* CTA line */
.impact-card p:last-child {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--csfwr-accent-red);
	margin-top: auto !important;
	margin-bottom: 0 !important;
}

.impact-card p:last-child a {
	color: var(--csfwr-accent-red);
	text-decoration: none;
}

.impact-card p:last-child::after {
	content: '';
	display: inline-block;
	width: 18px;
	height: 18px;
	margin-left: 0.375rem;
	vertical-align: -4px;
	background-color: var(--csfwr-accent-red);
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='m12 5 7 7-7 7'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='m12 5 7 7-7 7'/%3E%3C/svg%3E");
	-webkit-mask-size: contain;
	mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	flex-shrink: 0;
	transition: transform 0.2s ease;
}

.impact-card:hover p:last-child::after {
	transform: translateX(10px);
}

.impact-card:hover p:last-child {
	text-decoration: none;
}

/* 4-col grid variant */
.impact-cards-grid--4col.wp-block-group {
	grid-template-columns: repeat(4, 1fr) !important;
}

/* Icon card variant — centered, no border, no link behavior */
.impact-card--icon {
	align-items: center !important;
	text-align: center;
	border: none !important;
	min-height: auto !important;
	padding: 1.5rem 1rem !important;
}

.impact-card--icon:hover {
	border-color: transparent !important;
	box-shadow: none !important;
}

/* 80x80 box, icon stroke stays same visual size via increased padding */
.impact-card--icon svg {
	width: 80px !important;
	height: 80px !important;
	padding: 26px !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	transition: transform 0.2s ease !important;
}

.impact-card--icon:hover svg {
	transform: scale(1.08);
}

/* Heading */
.impact-card--icon .wp-block-heading {
	font-size: 1.25rem !important;
	text-align: center;
}

/* Description — reset CTA styles since there's no link */
.impact-card--icon p:last-child {
	color: #374151 !important;
	font-size: 1rem !important;
	line-height: 1.6 !important;
	font-weight: 400 !important;
	text-align: center;
	margin-top: 0.25rem !important;
}

.impact-card--icon p:last-child::after {
	display: none !important;
}

/* Disable stretched link on icon cards */
.impact-card--icon p:last-child a::after {
	display: none !important;
}

/* Responsive: 2-col on tablet, 1-col on mobile */
@media (max-width: 900px) {
	.impact-cards-grid.wp-block-group {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 560px) {
	.impact-cards-grid.wp-block-group {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 700px) {
	.impact-cards-grid--4col.wp-block-group {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (max-width: 400px) {
	.impact-cards-grid--4col.wp-block-group {
		grid-template-columns: 1fr !important;
	}
}

/* ── Donate Page ─────────────────────────────────────────────────────────────── */

/* Section wrapper — full-width light gray breakout */
.donate-section {
	width: 100vw !important;
	max-width: 100vw !important;
	margin-left: calc(50% - 50vw) !important;
	margin-right: calc(50% - 50vw) !important;
	background-color: #f9fafb;
	padding: clamp(3rem, 6vw, 5rem) var(--wp--preset--spacing--40);
}

.donate-section > .wp-block-heading {
	text-align: center;
	margin-bottom: 0.5rem !important;
}

.donate-section > p {
	text-align: center;
	color: var(--csfwr-muted);
	margin-bottom: 2rem !important;
}

/* Constrain donate-section inner content to 960px centered */
.donate-section > * {
	max-width: 960px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Donate card */
.donate-card {
	border: 1px solid var(--csfwr-border);
	padding: 2rem !important;
	background-color: var(--csfwr-white);
	margin-bottom: 0 !important;
}

.donate-card > * {
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.donate-card > .wp-block-heading {
	color: var(--csfwr-primary-dark) !important;
	margin-top: 0 !important;
	margin-bottom: 1.5rem !important;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--csfwr-border);
}

/* Checklist group */
.donate-checklist > * {
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* Checklist item */
.donate-checklist__item {
	position: relative;
	padding-left: 2rem !important;
	padding-bottom: 1.25rem;
	margin-bottom: 1.25rem;
	border-bottom: 1px solid var(--csfwr-border);
}

.donate-checklist__item:last-child {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.donate-checklist__item > * {
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* Red circle checkmark via inline SVG data URI */
.donate-checklist__item::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.2rem;
	width: 20px;
	height: 20px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='12' fill='%23c41230'/%3E%3Cpath d='M7 12l3 3 7-7' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
}

.donate-checklist__item h4.wp-block-heading {
	font-weight: 700 !important;
	color: var(--csfwr-primary-dark) !important;
	margin-top: 0 !important;
	margin-bottom: 0.35rem !important;
}

.donate-checklist__item p {
	line-height: 1.6;
	margin: 0 !important;
}

.donate-checklist__item p + p {
	margin-top: 0.35rem !important;
}

/* Red button — solid red fill, used for primary CTAs (e.g. donate links) */
.red-button {
	display: inline-block;
	background-color: var(--csfwr-accent-red) !important;
	color: #fff !important;
	border: 2px solid var(--csfwr-accent-red) !important;
	padding: 0.25rem 1.75rem !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	border-radius: var(--csfwr-radius) !important;
	text-decoration: none !important;
	transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease !important;
}

.red-button:hover {
	background-color: var(--csfwr-accent-red-h) !important;
	border-color: var(--csfwr-accent-red-h) !important;
	color: #fff !important;
	text-decoration: none !important;
}

/* Red arrow SVG — inline icon used alongside .red-button */
@keyframes arrow-slide {
	0%, 100% { transform: translateX(0); }
	50%       { transform: translateX(8px); }
}

.red-arrow {
	color: var(--csfwr-accent-red) !important;
	vertical-align: middle;
	display: inline-block;
	margin-right: 0.3rem;
	animation: arrow-slide 1s ease-in-out infinite;
}

/* Button inside donate card */
.donate-section .wp-block-buttons {
	margin-top: 1.75rem;
	justify-content: center;
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* Transparency card */
.donate-transparency {
	background-color: #ffffff !important;
	border: 2px solid var(--csfwr-navy);
	border-radius: var(--csfwr-radius);
	padding: 1.5rem 2rem !important;
	margin-top: 1.5rem;
	text-align: center;
}

.donate-transparency > * {
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.donate-transparency h4.wp-block-heading {
	font-weight: 700 !important;
	font-style: normal !important;
	color: var(--csfwr-primary-dark) !important;
	margin-top: 0 !important;
	margin-bottom: 0.75rem !important;
}

.donate-transparency p {
	font-size: 0.9375rem;
	color: var(--csfwr-muted);
	line-height: 1.65;
	margin: 0 !important;
}

/* ── Responsive ─────────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
	.header-inner {
		flex-wrap: wrap;
		gap: 0.75rem;
	}
}

@media (max-width: 768px) {
	.hero-inner {
		padding-top: 4rem !important;
		padding-bottom: 4rem !important;
	}

	.hero-heading {
		font-size: clamp(1.75rem, 6vw, 2.5rem) !important;
	}

	.featured-response-card .wp-block-columns {
		flex-direction: column;
	}

	.featured-response-card .wp-block-column {
		flex-basis: 100% !important;
		width: 100% !important;
		max-width: 100% !important;
	}

	.featured-response-card .wp-block-column:first-child {
		min-height: 240px;
	}

	.featured-card-meta {
		flex-direction: column !important;
		align-items: flex-start !important;
	}

	.featured-read-more {
		order: 1;
	}

	.newsletter-card {
		padding: 2rem 1.5rem;
	}

	.newsletter-form-wrap {
		flex-direction: column;
	}

	.newsletter-form-wrap .newsletter-submit {
		width: 100%;
	}
}

@media (max-width: 600px) {
	.site-name-group .site-name {
		font-size: 0.8rem;
	}

	.section-support-cta .wp-block-buttons {
		flex-direction: column;
		align-items: center;
	}
}

/* ── Utility ────────────────────────────────────────────────────────────────── */

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ── Editor Adjustments ─────────────────────────────────────────────────────── */

.wp-site-blocks > * + * {
	margin-top: 0;
}

/* Post title in block editor */
.editor-post-title__input,
.editor-post-title textarea,
.wp-block-post-title[contenteditable] {
	font-family: "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
	font-weight: 700 !important;
}

/* ── Why Support Us section ── */
.why-support-section {
	padding-top: clamp(3rem, 6vw, 5rem);
	padding-bottom: clamp(3rem, 6vw, 5rem);
}

.why-support-section > .wp-block-heading {
	margin-bottom: 2.5rem !important;
}

.why-support-section .wp-block-columns {
	align-items: flex-start !important;
	margin-bottom: 1.75rem !important;
	gap: 1.25rem !important;
}

.why-support-section .wp-block-columns:last-child {
	margin-bottom: 0 !important;
}

.why-support-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background-color: #fef9f3;
	border-radius: 6px;
	flex-shrink: 0;
}

.why-support-icon svg {
	width: 28px;
	height: 28px;
	stroke: var(--csfwr-accent-red);
}

.wp-block-column.why-support-item h4.wp-block-heading {
	color: var(--csfwr-primary-dark) !important;
	margin-top: 0.25rem !important;
	margin-bottom: 0.4rem !important;
}

.wp-block-column.why-support-item p {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

/* ── Contact Page ── */

/* Two-column layout gap and alignment */
.wp-block-columns:has(.contact-form-col) {
	gap: 3rem !important;
	align-items: flex-start !important;
}

/* Contact cards — shared */
.contact-card {
	display: flex !important;
	flex-direction: row !important;
	align-items: flex-start !important;
	gap: 1rem !important;
	border: 1px solid var(--csfwr-border) !important;
	background-color: #f9fafb;
	padding: 1.25rem !important;
	margin-bottom: 1rem !important;
	border-radius: var(--csfwr-radius) !important;
}

/* Icon circle */
.contact-icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	min-width: 48px;
	background-color: var(--csfwr-primary-dark);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.contact-icon svg {
	width: 22px !important;
	height: 22px !important;
	color: #fff;
	stroke: #fff;
	flex-shrink: 0;
}

/* Text group inside card */
.contact-card > .wp-block-group {
	flex: 1 !important;
	min-width: 0;
}

/* Card headings (built as H2 in editor, should look like H4) */
.contact-card h4.wp-block-heading {
	font-size: 1.5rem !important;
	font-weight: 600 !important;
	color: var(--csfwr-primary-dark) !important;
	margin-top: 0.1rem !important;
	margin-bottom: 0.2rem !important;
}

/* Card body text */
.contact-card > .wp-block-group p {
	color: var(--csfwr-text);
	margin: 0 !important;
	font-size: 0.95rem;
}

/* Links inside cards (email, phone) */
.contact-card > .wp-block-group p a {
	color: var(--csfwr-accent-red) !important;
	text-decoration: none;
}

/* Hours card — no icon, column layout */
.contact-card--hours {
	flex-direction: column !important;
	align-items: flex-start !important;
}

.contact-card--hours > * {
	margin-left: 0 !important;
	margin-right: 0 !important;
	max-width: none !important;
	text-align: left !important;
}

.contact-card--hours h2.wp-block-heading {
	margin-bottom: 0.5rem !important;
}

.contact-card--hours p {
	color: var(--csfwr-text) !important;
	margin-top: 0 !important;
	margin-bottom: 0.15rem !important;
}

.contact-note {
	color: var(--csfwr-muted) !important;
	font-size: 0.875rem !important;
	margin-top: 0.5rem !important;
}

/* Right column intro text */
.contact-form-col > p {
	color: var(--csfwr-muted);
	margin-bottom: 1.5rem !important;
}

/* ── Contact Form 7 ── */
.wpcf7-form p {
	margin-bottom: 1rem !important;
}

.wpcf7-form label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--csfwr-primary-dark);
	margin-bottom: 0.35rem;
}

.wpcf7-form-control.wpcf7-text,
.wpcf7-form-control.wpcf7-email,
.wpcf7-form-control.wpcf7-textarea {
	width: 100% !important;
	border: 1px solid var(--csfwr-border) !important;
	border-radius: var(--csfwr-radius) !important;
	padding: 0.65rem 0.875rem !important;
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: 1rem !important;
	color: var(--csfwr-text) !important;
	background-color: #fff !important;
	transition: border-color 0.2s ease !important;
	outline: none !important;
}

.wpcf7-form-control.wpcf7-text:focus,
.wpcf7-form-control.wpcf7-email:focus,
.wpcf7-form-control.wpcf7-textarea:focus {
	border-color: var(--csfwr-accent-red) !important;
	box-shadow: 0 0 0 3px rgba(196, 18, 48, 0.1) !important;
}

.wpcf7-form-control.wpcf7-textarea {
	min-height: 140px !important;
	resize: vertical !important;
}

.wpcf7-form-control.wpcf7-submit {
	width: 100% !important;
	background-color: var(--csfwr-accent-red) !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.536 21.686a.5.5 0 0 0 .937-.024l6.5-19a.496.496 0 0 0-.635-.635l-19 6.5a.5.5 0 0 0-.024.937l7.93 3.18a2 2 0 0 1 1.112 1.11z'/%3E%3Cpath d='m21.854 2.147-10.94 10.939'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: calc(50% - 4.5rem) center !important;
	background-size: 20px 20px !important;
	color: #fff !important;
	border: none !important;
	padding: 0.85rem 2rem !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	border-radius: var(--csfwr-radius) !important;
	cursor: pointer !important;
	transition: background-color 0.2s ease !important;
	letter-spacing: 0.01em;
}

.wpcf7-form-control.wpcf7-submit:hover {
	background-color: var(--csfwr-accent-red-h) !important;
}

/* ══════════════════════════════════════════════════════════════
   SINGLE ARTICLE PAGE
   ══════════════════════════════════════════════════════════════ */

/* Back to Home link — constrained to match article header width */
.single-back-nav {
	margin: 0 !important;
}

/* Outer wrapper — full width with border */
.wp-block-group:has(> .single-back-nav) {
	border-bottom: 1px solid var(--csfwr-border);
	padding-bottom: 1rem !important;
}

/* Inner paragraph — constrained to match article header */
.single-back-nav {
	max-width: 760px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.single-back-nav a {
	color: var(--csfwr-primary-dark) !important;
	font-size: 0.875rem;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-weight: 500;
}

.single-back-nav a svg {
	flex-shrink: 0;
	vertical-align: middle;
}

.single-back-nav a:hover {
	color: var(--csfwr-primary-dark);
}

/* Article header — light background */
.single-article-header {
	background-color: #fff;
}

/* Category badge */
.article-category-badge {
	margin-bottom: 0.875rem !important;
}

.article-category-badge a {
	display: inline-block;
	font-family: var(--wp--preset--font-family--ui, sans-serif);
	font-size: 0.75rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.3rem 0.7rem;
	text-decoration: none !important;
	color: #fff !important;
	background-color: var(--csfwr-primary-dark);
}

.article-category-badge a[href*="analysis"],
.article-category-badge a[href*="analyses"] { background-color: #4a3f6b; }
.article-category-badge a[href*="fact-check"],
.article-category-badge a[href*="fact-checks"] { background-color: #1e6fad; }
.article-category-badge a[href*="policy"],
.article-category-badge a[href*="policies"] { background-color: #0f7566; }
.article-category-badge a[href*="response"],
.article-category-badge a[href*="responses"] { background-color: #c05621; }

/* Article H1 title */
.single-article-header .wp-block-post-title {
	font-size: clamp(1.875rem, 4vw, 3rem) !important;
	font-weight: 700 !important;
	color: var(--csfwr-primary-dark) !important;
	line-height: 1.2 !important;
	margin-bottom: 0.75rem !important;
}

/* Article excerpt / subtitle */
.single-article-header .wp-block-post-excerpt,
.single-article-header .wp-block-post-excerpt__excerpt {
	color: var(--csfwr-muted) !important;
	font-size: 1.0625rem !important;
	line-height: 1.6 !important;
	margin: 0 !important;
}

/* Meta row — author, date */
.single-post-meta {
	border-top: 1px solid var(--csfwr-border);
	padding-top: 1rem;
}

/* Inner flex row containing author + date */
.single-post-meta > .wp-block-group {
	display: flex !important;
	flex-direction: row !important;
	align-items: center !important;
	gap: 1.5rem !important;
	flex-wrap: wrap;
}

/* Author block — inline-flex so icon aligns with name */
.single-post-meta .wp-block-post-author {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
}

.single-post-meta .wp-block-post-author__name {
	color: var(--csfwr-text) !important;
	font-size: 0.875rem !important;
	font-weight: 600 !important;
	display: inline-flex !important;
	align-items: center !important;
}

/* Date block — inline-flex so icon aligns with text */
.single-post-meta .wp-block-post-date {
	display: inline-flex !important;
	align-items: center !important;
}

.single-post-meta .wp-block-post-date,
.single-post-meta .wp-block-post-date a {
	color: var(--csfwr-muted) !important;
	font-size: 0.875rem !important;
	text-decoration: none !important;
}

.single-post-meta .wp-block-post-date::before {
	content: '' !important;
	margin-right: 0 !important;
}

/* Red accent line below featured image */
.single-red-rule {
	height: 4px !important;
	background-color: var(--csfwr-accent-red) !important;
	border: none !important;
	margin: 0 !important;
	max-width: 100% !important;
}

/* ── Article body typography ── */

/* Lead paragraph — first paragraph in article */
.wp-block-post-content .wp-block-paragraph:first-child {
	font-size: 1.0625rem !important;
	font-weight: 600 !important;
	color: var(--csfwr-primary-dark) !important;
	line-height: 1.7 !important;
}

/* Body paragraphs */
.wp-block-post-content .wp-block-paragraph {
	line-height: 1.75;
	color: var(--csfwr-text);
}

/* Article headings */
body.single .wp-block-post-content h2.wp-block-heading {
	color: var(--csfwr-primary-dark) !important;
	margin-top: 2.25rem !important;
	margin-bottom: 0.75rem !important;
	font-size: 1.5rem !important;
	font-weight: 600 !important;
}

.wp-block-post-content h3.wp-block-heading {
	color: var(--csfwr-primary-dark) !important;
	margin-top: 1.75rem !important;
	margin-bottom: 0.5rem !important;
}

/* Links inside article body */
.wp-block-post-content a:not(.red-button):not(.wp-block-button__link) {
	color: var(--csfwr-accent-red);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.wp-block-post-content a:not(.red-button):not(.wp-block-button__link):hover {
	color: var(--csfwr-primary-dark);
}

/* ── Get Involved page — animated underline links ── */
body.page-id-22 .wp-block-post-content a:not(.wp-block-button__link) {
	color: var(--csfwr-accent-red);
	text-decoration: none !important;
	position: relative;
	display: inline-block;
}

body.page-id-22 .wp-block-post-content a:not(.wp-block-button__link)::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	height: 2px;
	background-color: var(--csfwr-accent-red);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.2s ease;
}

body.page-id-22 .wp-block-post-content a:not(.wp-block-button__link):hover::after {
	transform: scaleX(1);
}

body.page-id-22 .wp-block-post-content a:not(.wp-block-button__link):hover {
	color: var(--csfwr-accent-red);
}

/* ── Support Our Mission CTA box ── */
.article-support-cta {
	border: 2px solid var(--csfwr-primary-dark) !important;
	padding: 1.5rem 2rem !important;
	background-color: #fef9f3;
	border-radius: var(--csfwr-radius) !important;
}

.article-support-cta h4.wp-block-heading {
	font-weight: 700 !important;
	color: var(--csfwr-primary-dark) !important;
	font-size: 1.125rem !important;
	margin-top: 0 !important;
	margin-bottom: 0.5rem !important;
}

.article-support-cta p {
	margin-bottom: 0 !important;
}

.article-support-cta .wp-block-buttons {
	gap: 0.75rem;
}

/* ── Author Bio ── */
.article-author-bio.wp-block-post-author {
	display: flex !important;
	align-items: flex-start !important;
	gap: 1.25rem !important;
	padding: 0 !important;
	margin: 0 !important;
}

.article-author-bio .wp-block-post-author__avatar img {
	width: 56px !important;
	height: 56px !important;
	border-radius: 50% !important;
	object-fit: cover;
}

.article-author-bio .wp-block-post-author__content {
	flex: 1;
}

.article-author-bio .wp-block-post-author__name {
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: var(--csfwr-primary-dark) !important;
	margin-bottom: 0.2rem !important;
	display: block;
}

.article-author-bio .wp-block-post-author__bio {
	color: var(--csfwr-muted) !important;
	font-size: 0.9rem !important;
	line-height: 1.6 !important;
	margin: 0 !important;
}

/* ── Tag pills ── */
.article-tags {
	margin-top: 1.5rem !important;
}

.article-tags .wp-block-post-terms__separator {
	display: none !important;
}

.article-tags a {
	display: inline-block !important;
	background-color: var(--csfwr-light-gray) !important;
	color: var(--csfwr-text) !important;
	font-size: 0.8rem !important;
	padding: 0.25rem 0.875rem !important;
	border-radius: 20px !important;
	text-decoration: none !important;
	margin-right: 0.4rem !important;
	margin-bottom: 0.4rem !important;
}

.article-tags a:hover {
	background-color: var(--csfwr-border) !important;
}

/* ── Single article — layout fixes ── */

/* Excerpt: force it to stay in flow, not drift left */
.single-article-header .wp-block-post-excerpt {
	max-width: none !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	width: 100%;
}

.single-article-header .wp-block-post-excerpt__excerpt {
	color: var(--csfwr-muted) !important;
	font-size: 1.5rem !important;
	line-height: 1.6 !important;
	margin: 0 0 0.75rem !important;
	padding: 0 !important;
}

.single-article-header .wp-block-post-excerpt__more-link {
	display: none !important;
}

/* Constrain the header group itself to 760px, left-aligned within content */
.single-article-header {
	max-width: 832px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Support CTA buttons — ensure both show in a row */
.article-support-cta .wp-block-buttons {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap !important;
	gap: 0.75rem !important;
	max-width: none !important;
	margin-left: 0 !important;
}

.article-support-cta .wp-block-button {
	max-width: none !important;
	margin: 0 !important;
}

/* Single article featured image — constrain height */
.single-article-header ~ .wp-block-post-featured-image img,
.wp-block-post-featured-image.alignwide img {
	max-height: 480px !important;
	width: 100% !important;
	object-fit: cover !important;
	object-position: center !important;
	display: block !important;
}

/* ── Author / date icons (article cards + single post meta) ── */

/* Shared icon base */
.single-post-meta .wp-block-post-author__name::before,
.single-post-meta .wp-block-post-date::before {
	content: '';
	display: inline-block;
	width: 13px;
	height: 13px;
	mask-repeat: no-repeat;
	mask-size: contain;
	mask-position: center;
	background-color: currentColor;
	vertical-align: middle;
	margin-right: 0.25rem;
	flex-shrink: 0;
}

/* Person icon — author */
.single-post-meta .wp-block-post-author__name::before {
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
}

/* Calendar icon — date */
.single-post-meta .wp-block-post-date::before {
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='18' height='18' x='3' y='4' rx='2' ry='2'/%3E%3Cline x1='16' x2='16' y1='2' y2='6'/%3E%3Cline x1='8' x2='8' y1='2' y2='6'/%3E%3Cline x1='3' x2='21' y1='10' y2='10'/%3E%3C/svg%3E");
	margin-right: 0.35rem !important;
}

/* ── Share buttons ── */
.share-buttons {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.share-label {
	font-size: 0.8rem;
	color: var(--csfwr-muted);
	font-weight: 500;
	margin-right: 0.25rem;
}

.share-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border: 1px solid var(--csfwr-border);
	border-radius: 50%;
	background: #fff;
	color: var(--csfwr-muted);
	cursor: pointer;
	transition: border-color 0.2s ease, color 0.2s ease;
	padding: 0;
}

.share-btn:hover {
	border-color: var(--csfwr-primary-dark);
	color: var(--csfwr-primary-dark);
}

.share-btn--copied {
	border-color: #0f7566 !important;
	color: #0f7566 !important;
}

/* Copy link wrapper + "Link copied" message */
.share-copy-wrap {
	position: relative;
	display: flex;
	align-items: center;
}

.share-copied-msg {
	position: absolute;
	transform: translateX(-50%);
	white-space: nowrap;
	font-size: 0.75rem;
	font-weight: 600;
	color: #fff;
	background: #0f7566;
	padding: 0.25rem 0.65rem;
	border-radius: 4px;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease;
	z-index: 99999;
}

.share-copied-msg--visible {
	opacity: 1;
}

/* ── Article summary custom field ── */
.article-summary {
	color: #2d3748 !important;
	font-weight: 500 !important;
	font-size: 1.25rem !important;
}

/* Article summary separator */
.article-summary-rule {
	width: 50% !important;
	max-width: 50% !important;
	border: none !important;
	border-top: 1px solid var(--csfwr-border) !important;
	margin-top: 3rem !important;
	margin-bottom: 3rem !important;
}

/* ── Article CTA buttons ── */
.article-cta-btn .wp-block-button__link {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.5rem !important;
}

.article-cta-btn .wp-block-button__link svg {
	flex-shrink: 0;
}

/* Get Involved — transparent, navy border */
.cta-btn-outline.article-cta-btn .wp-block-button__link {
	background-color: transparent !important;
	color: var(--csfwr-primary-dark) !important;
	border: 2px solid var(--csfwr-primary-dark) !important;
}

.cta-btn-outline.article-cta-btn .wp-block-button__link:hover {
	background-color: var(--csfwr-primary-dark) !important;
	color: #fff !important;
}

/* Donate — red filled */
.cta-btn-donate.article-cta-btn .wp-block-button__link {
	background-color: var(--csfwr-accent-red) !important;
	color: #fff !important;
	border: 2px solid var(--csfwr-accent-red) !important;
}

.cta-btn-donate.article-cta-btn .wp-block-button__link:hover {
	background-color: var(--csfwr-accent-red-h) !important;
	border-color: var(--csfwr-accent-red-h) !important;
}

/* ══════════════════════════════════════════════════════════════
   MOBILE NAVIGATION
   ══════════════════════════════════════════════════════════════ */

/* Hamburger button — hidden on desktop */
.mobile-menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 40px;
	height: 40px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 4px;
	z-index: 200;
}

.hamburger-line {
	display: block;
	width: 24px;
	height: 2px;
	background-color: var(--csfwr-primary-dark);
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.25s ease;
}

/* Animate to X when open */
.mobile-menu-toggle.is-open .hamburger-line:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.mobile-menu-toggle.is-open .hamburger-line:nth-child(2) {
	opacity: 0;
}
.mobile-menu-toggle.is-open .hamburger-line:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

@media (max-width: 768px) {
	/* Show hamburger */
	.mobile-menu-toggle {
		display: flex;
	}

	/* Hide nav group by default on mobile */
	.header-nav-group {
		display: none !important;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background-color: #fff;
		border-top: 1px solid var(--csfwr-border);
		box-shadow: var(--csfwr-shadow-md);
		padding: 1.5rem var(--wp--preset--spacing--40);
		z-index: 150;
		flex-direction: column !important;
		align-items: flex-start !important;
	}

	/* Show when open */
	.header-nav-group.is-open {
		display: flex !important;
	}

	/* Stack nav links vertically */
	.csfwr-site-nav .csfwr-nav-list {
		flex-direction: column !important;
		align-items: flex-start !important;
		gap: 0 !important;
		width: 100%;
	}

	.csfwr-site-nav .csfwr-nav-list li {
		width: 100%;
		border-bottom: 1px solid var(--csfwr-border);
	}

	.csfwr-site-nav .csfwr-nav-list li a {
		display: block;
		padding: 0.85rem 0 !important;
		font-size: 1rem !important;
	}

	/* Stack buttons vertically */
	.header-nav-group .wp-block-buttons {
		flex-direction: column !important;
		width: 100%;
		margin-top: 1rem;
		gap: 0.5rem !important;
	}

	.header-nav-group .wp-block-button,
	.header-nav-group .wp-block-button__link {
		width: 100% !important;
		text-align: center !important;
		display: flex !important;
		justify-content: center !important;
	}

	/* Active nav link: text red, no background */
	.header-nav-group .csfwr-nav-list .current-menu-item > a,
	.header-nav-group .csfwr-nav-list .current_page_item > a {
		background-color: transparent !important;
		color: var(--csfwr-accent-red) !important;
		border-radius: 0;
	}

	.article-meta__arrow {
		display: none !important;
	}

	.red-arrow {
		display: none !important;
	}

	.donate-card .red-button {
		display: block !important;
		width: 100% !important;
		margin: 1.25rem auto 0 !important;
		text-align: center !important;
	}

	/* Principles section: stack cards, fix full-bleed overflow */
	.principles-section::before {
		width: 100% !important;
		left: 0 !important;
		transform: none !important;
	}

	.principles-section .wp-block-columns {
		flex-direction: column !important;
	}

	.principles-section .wp-block-column {
		flex-basis: 100% !important;
		width: 100% !important;
		max-width: 100% !important;
	}

	/* Footer: stack all columns vertically */
	.site-footer .wp-block-columns {
		flex-direction: column !important;
	}

	.site-footer .wp-block-column {
		flex-basis: 100% !important;
		width: 100% !important;
	}

	.site-footer .footer-nav-col {
		margin-top: 1.5rem !important;
		margin-bottom: 1.5rem !important;
	}

	/* Footer nav: never show the hamburger, always show links */
	.site-footer .wp-block-navigation__responsive-container-open,
	.site-footer .wp-block-navigation__responsive-container-close {
		display: none !important;
	}

	.site-footer .wp-block-navigation__responsive-container {
		display: block !important;
		position: static !important;
		background: transparent !important;
		padding: 0 !important;
	}

	.site-footer .wp-block-navigation__responsive-container-content {
		display: flex !important;
		flex-direction: column !important;
	}

	/* Make header position relative so dropdown anchors to it */
	.site-header {
		position: relative;
	}
}
