/**
 * GP + layout parity with Astro visitor portal.
 * Card surfaces: assets/cards.css (shared tokens from riverbend-tokens.css).
 */
body.rbfun-page {
	--radius: var(--border-radius-sm);
	--radius-xs: var(--border-radius-sm);
	--radius-s: var(--border-radius-sm);
	--radius-m: var(--border-radius-md);
	--radius-l: var(--border-radius-lg);
	--radius-xl: var(--border-radius-lg);
}

/* Archive headers stay square full-bleed bands */
body.rbfun-page .page-header,
body.rbfun-page .inside-page-header,
body.rbfun-page .paging-navigation,
body.rbfun-page .post-navigation {
	border-radius: 0 !important;
}

/* No-sidebar layouts — hide GP widget column */
body.rbfun-page.no-sidebar .sidebar,
body.rbfun-page.no-sidebar .widget-area {
	display: none !important;
}

/* Narrow reading column when no sidebar (not front page — PostX home is full width) */
body.rbfun-page.no-sidebar:not(.home) .site-main {
	max-width: 48rem;
	margin-left: auto;
	margin-right: auto;
}

/* Right-sidebar blog / singles — GP controls column widths */
body.rbfun-page.right-sidebar .site-main {
	max-width: none;
}

body.rbfun-page.right-sidebar .widget-area .widget {
	background: var(--color-card-bg);
	border: 1px solid rgba(30, 70, 32, 0.08);
	padding: 1.25rem;
	margin-bottom: 1.5rem;
}

body.rbfun-page.right-sidebar .widget-area .widget-title {
	font-family: var(--font-display);
	color: var(--color-primary);
	font-size: 1.125rem;
	margin-bottom: 0.75rem;
}

/* -------------------------------------------------------------------------
   GeneratePress global colors → River Bend tokens (inline GP CSS overrides)
   ------------------------------------------------------------------------- */
body.rbfun-page {
	--contrast: var(--color-text-dark);
	--contrast-2: var(--color-gray);
	--contrast-3: #a1a1aa;
	--base: var(--color-card-bg);
	--base-2: var(--color-bg-warm);
	--base-3: var(--color-card-bg);
	--accent: var(--color-primary);
	background-color: var(--color-bg-warm) !important;
	color: var(--color-text-dark);
}

body.rbfun-page .site-content {
	background-color: transparent;
}

body.rbfun-page .header a.header__link,
body.rbfun-page .header a.header__link:link,
body.rbfun-page .header a.header__link:visited {
	color: var(--color-text-dark);
}

body.rbfun-page a:not(.rb-btn):not(.header__link):not(.ultp-block-title a):not(.ultp-block-meta a):not(.header__weather-chip) {
	color: var(--color-primary);
}

body.rbfun-page a:not(.rb-btn):not(.header__link):not(.ultp-block-title a):not(.ultp-block-meta a):not(.header__weather-chip):hover,
body.rbfun-page a:not(.rb-btn):not(.header__link):not(.ultp-block-title a):not(.ultp-block-meta a):not(.header__weather-chip):focus {
	color: var(--color-secondary);
}

/* Archive / page hero band */
body.rbfun-page .page-header,
body.rbfun-page .inside-page-header {
	background: var(--color-primary) !important;
	color: var(--color-text-light) !important;
	border: none !important;
	margin-bottom: 1.5rem;
	padding: 2.5rem 1.5rem !important;
}

body.rbfun-page .page-header .page-title,
body.rbfun-page .page-header h1,
body.rbfun-page .archive-description {
	color: var(--color-text-light) !important;
	font-family: var(--font-display);
}

body.rbfun-page .archive-description {
	opacity: 0.92;
	font-size: 1rem;
	margin-top: 0.5rem;
}

/* Blog + archive article cards — margin handled in cards.css */
body.rbfun-page .entry-title,
body.rbfun-page .entry-title a {
	font-family: var(--font-display);
	color: var(--color-primary) !important;
	font-weight: 600;
	text-decoration: none;
}

body.rbfun-page .entry-title a:hover {
	color: var(--color-secondary) !important;
}

body.rbfun-page .entry-meta,
body.rbfun-page .entry-meta a {
	color: var(--color-gray) !important;
	font-size: 0.875rem;
}

body.rbfun-page .entry-meta a:hover {
	color: var(--color-primary) !important;
}

body.rbfun-page .entry-summary,
body.rbfun-page .entry-content {
	font-family: var(--font-body);
	line-height: 1.65;
}

body.rbfun-page .entry-content p {
	margin-bottom: 1rem;
}

body.rbfun-page .entry-content h2,
body.rbfun-page .entry-content h3,
body.rbfun-page .entry-content h4 {
	font-family: var(--font-display);
	color: var(--color-primary);
	margin-top: 1.5rem;
	margin-bottom: 0.75rem;
}

body.rbfun-page footer.entry-meta {
	border-top: 1px solid rgba(30, 70, 32, 0.1);
	padding-top: 0.75rem;
	margin-top: 1rem;
	font-size: 0.85rem;
}

body.rbfun-page footer.entry-meta a {
	color: var(--color-primary) !important;
	text-decoration: none;
}

body.rbfun-page footer.entry-meta a:hover {
	color: var(--color-secondary) !important;
}

/* Pagination */
body.rbfun-page .paging-navigation,
body.rbfun-page .post-navigation {
	background: var(--color-card-bg) !important;
	border: 1px solid rgba(30, 70, 32, 0.08);
}

body.rbfun-page .paging-navigation a,
body.rbfun-page .post-navigation a {
	color: var(--color-primary) !important;
	font-family: var(--font-display);
	font-weight: 600;
	text-decoration: none;
}

body.rbfun-page .paging-navigation a:hover,
body.rbfun-page .post-navigation a:hover {
	color: var(--color-secondary) !important;
}

/* Slim SEO breadcrumbs */
body.rbfun-page .slim-seo-breadcrumbs,
body.rbfun-page .ss-breadcrumb {
	font-size: 0.875rem;
	margin-bottom: 1rem;
	color: var(--color-gray);
}

body.rbfun-page .slim-seo-breadcrumbs a,
body.rbfun-page .ss-breadcrumb a {
	color: var(--color-primary);
	text-decoration: none;
}

body.rbfun-page .slim-seo-breadcrumbs a:hover,
body.rbfun-page .ss-breadcrumb a:hover {
	color: var(--color-secondary);
}

/* Sidebar widget lists */
body.rbfun-page .widget-area ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

body.rbfun-page .widget-area li {
	margin-bottom: 0.5rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid rgba(30, 70, 32, 0.08);
}

body.rbfun-page .widget-area li:last-child {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

body.rbfun-page .widget-area a {
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 500;
}

body.rbfun-page .widget-area a:hover {
	color: var(--color-secondary);
}

body.rbfun-page .widget-area p {
	font-size: 0.9rem;
	color: var(--color-gray);
	line-height: 1.5;
}

/* GP buttons → River Bend */
body.rbfun-page button,
body.rbfun-page input[type='submit'],
body.rbfun-page input[type='reset'],
body.rbfun-page .button,
body.rbfun-page a.button {
	background-color: var(--color-primary) !important;
	color: var(--color-text-light) !important;
	border: none !important;
	font-family: var(--font-display) !important;
	font-weight: 600 !important;
}

body.rbfun-page button:hover,
body.rbfun-page input[type='submit']:hover,
body.rbfun-page .button:hover,
body.rbfun-page a.button:hover {
	background-color: var(--color-primary-light) !important;
}

body.rbfun-page a.generate-back-to-top {
	background-color: var(--color-primary) !important;
	color: var(--color-text-light) !important;
}

/* Front page: custom hero replaces GP page title (WP uses body.home, not .front-page) */
body.rbfun-page.home .inside-article > .entry-header {
	display: none;
}

/* Static pages (calendar, contact) */
body.rbfun-page.page .entry-header .entry-title {
	font-family: var(--font-display);
	color: var(--color-primary);
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	margin-bottom: 0.75rem;
}

body.rbfun-page.page .entry-content {
	max-width: 48rem;
}

body.rbfun-page.page.no-sidebar .site-main > article {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
}

/* GP right-sidebar — stack main + sidebar below desktop nav breakpoint */
@media (max-width: 991px) {
	body.rbfun-page.right-sidebar .content-area {
		display: flex;
		flex-direction: column;
	}

	body.rbfun-page.right-sidebar .site-main,
	body.rbfun-page.right-sidebar .sidebar,
	body.rbfun-page.right-sidebar .widget-area {
		width: 100% !important;
		float: none !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		max-width: none !important;
	}

	body.rbfun-page.right-sidebar .sidebar,
	body.rbfun-page.right-sidebar .widget-area {
		order: 2;
		margin-top: 1.5rem;
	}
}

/* Lista / FullCalendar — allow horizontal scroll inside wrapper only */
@media (max-width: 640px) {
	body.rbfun-page .lre-calendar-wrapper {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	body.rbfun-page .lre-calendar-wrapper .fc {
		min-width: 280px;
	}
}
