/**
 * Meitner — Main Stylesheet
 *
 * Design tokens are defined in theme.json and extended here.
 * Dark mode overrides WordPress preset variables directly.
 *
 * @package meitner
 */

/* =========================================================================
   Custom Properties — aliases & dark mode
   ========================================================================= */

:root {
	--c-bg: var(--wp--preset--color--background);
	--c-surface: var(--wp--preset--color--surface);
	--c-surface-raised: var(--wp--preset--color--surface-raised);
	--c-border: var(--wp--preset--color--border);
	--c-border-light: var(--wp--preset--color--border-light);
	--c-text: var(--wp--preset--color--text);
	--c-text-secondary: var(--wp--preset--color--text-secondary);
	--c-text-tertiary: var(--wp--preset--color--text-tertiary);
	--c-primary: var(--wp--preset--color--primary);
	--c-primary-brand: var(--wp--preset--color--primary-brand);
	--c-primary-light: var(--wp--preset--color--primary-light);
	--c-primary-hover: var(--wp--preset--color--primary-hover);
	--c-accent: var(--wp--preset--color--accent);
	--c-accent-light: var(--wp--preset--color--accent-light);
	--c-accent-hover: #d4005b;
	--c-tag-bg: #f0eaec;
	--c-tag-text: #505050;
	--c-hero-gradient-start: #f6eff1;
	--c-hero-gradient-end: #fafaf8;
	--c-card-shadow: rgba(0, 0, 0, 0.04);
	--c-card-shadow-hover: rgba(0, 0, 0, 0.08);
	--f-display: var(--wp--preset--font-family--display);
	--f-body: var(--wp--preset--font-family--body);
	--f-mono: var(--wp--preset--font-family--mono);
	--radius: var(--wp--custom--border--radius);
	--radius-lg: var(--wp--custom--border--radius-lg);
}

/* Dark mode overrides */
[data-theme="dark"] {
	--wp--preset--color--background: #121210;
	--wp--preset--color--surface: #1c1b19;
	--wp--preset--color--surface-raised: #262324;
	--wp--preset--color--border: #3a3436;
	--wp--preset--color--border-light: #302a2c;
	--wp--preset--color--text: #e5e4e0;
	--wp--preset--color--text-secondary: #a5a4a0;
	--wp--preset--color--text-tertiary: #918f8b;
	--wp--preset--color--primary: #ff4d94;
	--wp--preset--color--primary-brand: #ff006e;
	--wp--preset--color--primary-light: #2e1420;
	--wp--preset--color--primary-hover: #ff6ba6;
	--wp--preset--color--accent: #ff4d94;
	--wp--preset--color--accent-light: #2e1420;
	--c-accent-hover: #ff6ba6;
	--c-tag-bg: #2a2526;
	--c-tag-text: #a5a4a0;
	--c-hero-gradient-start: #1c1b19;
	--c-hero-gradient-end: #121210;
	--c-card-shadow: rgba(0, 0, 0, 0.2);
	--c-card-shadow-hover: rgba(0, 0, 0, 0.35);
	color-scheme: dark;
}

/* =========================================================================
   Reset & Base
   ========================================================================= */

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

html {
	scroll-behavior: smooth;
}

body {
	-webkit-font-smoothing: antialiased;
}

a {
	text-decoration: underline;
	text-decoration-color: currentColor;
	text-underline-offset: 2px;
	transition: color 0.15s, text-decoration-color 0.15s;
}

a:hover {
	text-decoration-color: transparent;
}

/* Remove underlines from header navigation and button-styled links */
.site-nav a,
.site-logo,
.skip-link,
.hero-cta,
.load-more-btn,
.feed-filter,
.micro-nav-link,
.micro-card__tag,
.meitner-post-category a,
.meitner-feed-tags a,
.speaker-link,
.author-box-link,
.about-link,
.meitner-about-link,
.fedi-discuss,
.lang-switch,
.page-numbers,
.wp-block-button__link,
.wp-element-button {
	text-decoration: none;
}

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

::selection {
	background: var(--c-primary-brand);
	color: #fff;
}

:focus-visible {
	outline: 2px solid var(--c-primary);
	outline-offset: 2px;
}

strong {
	font-weight: 600;
}

/* =========================================================================
   Skip Link
   ========================================================================= */

.skip-link {
	position: absolute;
	top: -100%;
	left: 16px;
	background: var(--c-primary);
	color: #fff;
	padding: 8px 16px;
	border-radius: var(--radius);
	font-weight: 600;
	z-index: 1000;
}

.skip-link:focus {
	top: 16px;
	color: #fff;
}

/* =========================================================================
   Header
   ========================================================================= */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	border-bottom: 1px solid var(--c-border-light);
	backdrop-filter: blur(12px);
	background: color-mix(in srgb, var(--c-bg) 88%, transparent);
}

.header-inner {
	max-width: var(--wp--custom--width--page);
	margin: 0 auto;
	padding: 12px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.site-logo {
	font-family: var(--f-display);
	font-weight: 600;
	font-size: 20px;
	color: var(--c-text);
}

.site-logo:hover {
	color: var(--c-primary);
}

/* Navigation */
.site-nav {
	display: flex;
	align-items: center;
	gap: 2px;
	list-style: none;
}

.site-nav ul {
	display: contents;
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-nav .menu-item {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-nav a,
.site-nav .menu-item a {
	font-size: 14px;
	font-weight: 500;
	color: var(--c-text-secondary);
	padding: 6px 11px;
	border-radius: 6px;
	transition: color 0.15s, background 0.15s;
}

.site-nav a:hover,
.site-nav .menu-item a:hover {
	color: var(--c-text);
	background: var(--c-surface-raised);
}

.site-nav .current-menu-item > a,
.site-nav .current_page_item > a {
	color: var(--c-primary);
	background: var(--c-primary-light);
}

.nav-separator {
	width: 1px;
	height: 16px;
	background: var(--c-border);
	margin: 0 4px;
}

.lang-switch {
	font-size: 13px;
	font-family: var(--f-mono);
	font-weight: 600;
	color: var(--c-text-tertiary);
	padding: 4px 8px;
	border-radius: 4px;
	border: 1px solid transparent;
}

.lang-switch:hover {
	color: var(--c-primary);
}

.lang-switch.active-lang {
	background: var(--c-primary-light);
	border-color: var(--c-primary);
	color: var(--c-primary);
}

.theme-toggle {
	background: none;
	border: 1px solid var(--c-border);
	border-radius: 6px;
	padding: 5px 8px;
	cursor: pointer;
	color: var(--c-text-secondary);
	font-size: 15px;
	line-height: 1;
	transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.theme-toggle:hover {
	border-color: var(--c-accent);
	color: var(--c-accent);
}

.nav-toggle {
	display: none;
	background: none;
	border: none;
	color: var(--c-text);
	font-size: 22px;
	cursor: pointer;
	padding: 8px;
}

@media (max-width: 820px) {
	.nav-toggle {
		display: block;
	}

	.site-nav {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--c-bg);
		border-bottom: 1px solid var(--c-border);
		padding: 16px 24px;
		flex-direction: column;
		align-items: stretch;
		gap: 2px;
	}

	.site-nav.open {
		display: flex;
	}

	.nav-separator {
		display: none;
	}

	.site-nav a,
	.site-nav .menu-item a {
		padding: 10px 12px;
	}
}

/* =========================================================================
   Common
   ========================================================================= */

.page-wrap {
	max-width: var(--wp--custom--width--page);
	margin: 0 auto;
	padding: 0 24px;
}

.page-header {
	padding: 48px 24px 24px;
	max-width: var(--wp--custom--width--page);
	margin: 0 auto;
}

.page-slug {
	font-family: var(--f-mono);
	font-size: 13px;
	color: var(--c-text-tertiary);
	margin-bottom: 4px;
}

.page-title {
	font-family: var(--f-display);
	font-size: 30px;
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.15;
}

.page-subtitle {
	font-size: 16px;
	color: var(--c-text-secondary);
	margin-top: 6px;
	max-width: 520px;
	line-height: 1.5;
}

.section-label {
	font-family: var(--f-mono);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--c-text-tertiary);
	margin-bottom: 16px;
	padding-top: 32px;
}

/* =========================================================================
   Hero
   ========================================================================= */

.hero {
	padding: 48px 0 32px;
	background: linear-gradient(180deg, var(--c-hero-gradient-start) 0%, var(--c-hero-gradient-end) 100%);
	border-bottom: 1px solid var(--c-border-light);
}

.hero-inner {
	max-width: var(--wp--custom--width--page);
	margin: 0 auto;
	padding: 0 24px;
	display: flex;
	align-items: center;
	gap: 24px;
}

.hero-avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	flex-shrink: 0;
	border: 3px solid var(--c-surface);
	box-shadow: 0 2px 10px var(--c-card-shadow);
	background: var(--c-surface-raised);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 32px;
	color: var(--c-primary);
	font-family: var(--f-display);
	font-weight: 600;
	overflow: hidden;
}

.hero-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-content {
	flex: 1;
}

.hero-name {
	font-family: var(--f-display);
	font-size: 24px;
	font-weight: 600;
	letter-spacing: -0.02em;
}

.hero-tagline {
	font-size: 15px;
	color: var(--c-text-secondary);
	line-height: 1.5;
	max-width: 500px;
	margin-top: 2px;
}

.hero-links {
	margin-top: 16px;
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}

.hero-social {
	font-size: 14px;
	font-weight: 500;
	color: var(--c-text-secondary);
}

.hero-social:hover {
	color: var(--c-primary);
}

.hero-cta {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 14px;
	font-weight: 600;
	color: #fff;
	background: var(--c-primary-brand);
	padding: 6px 14px;
	border-radius: 6px;
	transition: background 0.15s;
}

.hero-cta:hover {
	background: var(--c-accent-hover);
	color: #fff;
}

/* =========================================================================
   Hero — Block Pattern
   ========================================================================= */

.meitner-hero {
	background: linear-gradient(180deg, var(--c-hero-gradient-start) 0%, var(--c-hero-gradient-end) 100%);
	border-bottom: 1px solid var(--c-border-light);
}

.meitner-hero-avatar {
	width: 80px;
	height: 80px;
	min-width: 80px;
	border-radius: 50%;
	border: 3px solid var(--c-surface);
	box-shadow: 0 2px 10px var(--c-card-shadow);
	background: var(--c-surface-raised);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.meitner-hero-avatar p {
	margin: 0;
}

.meitner-hero-avatar figure {
	margin: 0;
	line-height: 0;
}

.meitner-hero-avatar img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: 50%;
	display: block;
}

.meitner-hero-social a {
	color: var(--c-text-secondary);
}

.meitner-hero-social a:hover {
	color: var(--c-primary);
}

@media (max-width: 560px) {
	.meitner-hero > .wp-block-group {
		flex-direction: column;
		align-items: flex-start;
	}

	.meitner-hero-avatar {
		width: 64px;
		height: 64px;
		min-width: 64px;
	}

	.meitner-hero-avatar img {
		width: 64px;
		height: 64px;
	}
}

/* =========================================================================
   Latest Posts — Block Query Loop
   ========================================================================= */

.meitner-section-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 8px;
}

.meitner-section-header h2 {
	margin: 0;
}

.meitner-section-header p {
	margin: 0;
}

.meitner-post-cards {
	display: flex;
	flex-direction: column;
	gap: 1px;
	background: var(--c-border-light);
	border-radius: var(--radius-lg);
	overflow: hidden;
	margin-bottom: 48px;
	list-style: none;
	padding: 0;
}

/* Override WordPress flow layout gap on the post template <ul> */
.meitner-post-cards.wp-block-post-template {
	--wp--style--block-gap: 0px;
}

.meitner-post-cards > .wp-block-post {
	background: var(--c-surface);
	transition: background 0.15s;
	list-style: none;
	margin: 0;
}

.meitner-post-cards > .wp-block-post:hover {
	background: var(--c-surface-raised);
}

.meitner-post-card {
	padding: 32px;
}

/* Override constrained layout within cards — content should fill the card */
.meitner-post-card.is-layout-constrained > * {
	max-width: none;
}

.meitner-post-card .wp-block-post-title {
	font-size: 20px;
	margin: 0;
}

.meitner-post-card .wp-block-post-title a {
	color: var(--c-text);
}

.meitner-post-cards > .wp-block-post:hover .wp-block-post-title a {
	color: var(--c-primary);
}

.meitner-post-card .wp-block-post-excerpt {
	margin: 0;
}

.meitner-post-card .wp-block-post-excerpt__excerpt {
	font-size: 15px;
	color: var(--c-text-secondary);
	line-height: 1.6;
	margin-bottom: 0;
}

.meitner-post-card .wp-block-read-more {
	font-size: 14px;
	font-weight: 500;
	margin-top: 8px;
	display: inline-block;
}

.meitner-post-category {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 6px;
}

.meitner-post-category a {
	font-family: var(--f-body);
	font-weight: 600;
	font-size: 12px;
	color: var(--c-primary);
	background: var(--c-primary-light);
	padding: 2px 7px;
	border-radius: 4px;
}

/* =========================================================================
   Blog List
   ========================================================================= */

.blog-section-header-inner {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	padding: 32px 0 16px;
}

.blog-section-title {
	font-family: var(--f-display);
	font-size: 20px;
	font-weight: 600;
}

.blog-section-link {
	font-size: 14px;
	font-weight: 500;
	color: var(--c-text-tertiary);
}

.blog-section-link:hover {
	color: var(--c-primary);
}

.post-list {
	display: flex;
	flex-direction: column;
	gap: 1px;
	background: var(--c-border-light);
	border-radius: var(--radius-lg);
	overflow: hidden;
	margin-bottom: 48px;
}

.post-card {
	background: var(--c-surface);
	transition: background 0.15s;
	position: relative;
	padding: 32px;
}

.post-card:hover {
	background: var(--c-surface-raised);
}

.post-card-link {
	color: inherit;
}

.post-card-link::after {
	content: "";
	position: absolute;
	inset: 0;
}

.post-card-link:focus-visible {
	outline: none;
}

.post-card-link:focus-visible::after {
	outline: 2px solid var(--c-primary);
	outline-offset: -2px;
	border-radius: inherit;
}

.post-meta {
	font-size: 13px;
	font-family: var(--f-mono);
	color: var(--c-text-tertiary);
	margin-bottom: 6px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.post-category {
	font-family: var(--f-body);
	font-weight: 600;
	font-size: 12px;
	color: var(--c-primary);
	background: var(--c-primary-light);
	padding: 2px 7px;
	border-radius: 4px;
}

.post-title {
	font-family: var(--f-display);
	font-size: 20px;
	font-weight: 600;
	letter-spacing: -0.01em;
	margin-bottom: 6px;
	color: var(--c-text);
	line-height: 1.3;
}

.post-card:hover .post-card-link {
	color: var(--c-primary);
}

.post-excerpt {
	font-size: 15px;
	color: var(--c-text-secondary);
	line-height: 1.6;
}

.post-continue {
	font-size: 14px;
	font-weight: 500;
	color: var(--c-primary);
	margin-top: 8px;
	display: inline-block;
}

/* =========================================================================
   About
   ========================================================================= */

.about-layout {
	max-width: var(--wp--custom--width--page);
	margin: 0 auto;
	padding: 48px 24px 64px;
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 64px;
	align-items: start;
}

@media (max-width: 768px) {
	.about-layout {
		grid-template-columns: 1fr;
		gap: 32px;
	}
}

.about-photo-col {
	position: sticky;
	top: 80px;
}

.about-photo {
	width: 100%;
	aspect-ratio: 3 / 4;
	border-radius: var(--radius-lg);
	background: linear-gradient(135deg, var(--c-surface-raised), var(--c-primary-light));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 72px;
	color: var(--c-primary);
	font-family: var(--f-display);
	font-weight: 600;
	overflow: hidden;
}

.about-photo img,
.about-photo-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--radius-lg);
}

.about-credit {
	font-size: 12px;
	color: var(--c-text-tertiary);
	margin-top: 6px;
	text-align: center;
}

.about-body h2 {
	font-family: var(--f-display);
	font-size: 26px;
	font-weight: 600;
	letter-spacing: -0.02em;
	margin-bottom: 24px;
	line-height: 1.2;
}

.about-body p {
	font-size: 16px;
	line-height: 1.7;
	color: var(--c-text-secondary);
	margin-bottom: 24px;
}

.about-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin: 32px 0;
	padding: 24px;
	background: var(--c-surface-raised);
	border-radius: var(--radius-lg);
}

@media (max-width: 480px) {
	.about-stats {
		grid-template-columns: 1fr;
	}
}

.stat-number {
	font-family: var(--f-display);
	font-size: 30px;
	font-weight: 600;
	color: var(--c-primary);
	line-height: 1.1;
	text-align: center;
}

.stat-label {
	font-size: 13px;
	color: var(--c-text-tertiary);
	text-align: center;
	margin-top: 2px;
}

.about-links {
	display: flex;
	gap: 8px;
	margin-top: 32px;
	flex-wrap: wrap;
}

.about-link {
	font-size: 14px;
	font-weight: 600;
	color: var(--c-text-secondary);
	padding: 7px 14px;
	border: 1px solid var(--c-border);
	border-radius: 6px;
	transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.about-link:hover {
	border-color: var(--c-primary);
	color: var(--c-primary);
}

/* =========================================================================
   Single Post
   ========================================================================= */

.single-wrap {
	max-width: var(--wp--custom--width--reading);
	margin: 0 auto;
	padding: 48px 24px 64px;
}

.single-meta {
	font-family: var(--f-mono);
	font-size: 13px;
	color: var(--c-text-tertiary);
	margin-bottom: 16px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.single-title {
	font-family: var(--f-display);
	font-size: 34px;
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.15;
	margin-bottom: 32px;
}

.single-body {
	font-size: 18px;
	line-height: 1.75;
	color: var(--c-text-secondary);
}

.single-body p {
	margin-bottom: 24px;
}

.single-body a {
	text-decoration: underline;
	text-decoration-color: var(--c-primary);
	text-underline-offset: 3px;
}

.single-tags {
	margin-top: 24px;
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

/* =========================================================================
   Author Box
   ========================================================================= */

.author-box {
	margin-top: 48px;
	padding: 32px;
	border-radius: var(--radius-lg);
	background: var(--c-surface-raised);
	border: 1px solid var(--c-border-light);
}

.author-box-header {
	display: flex;
	align-items: center;
	gap: 16px;
}

.author-box-avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	flex-shrink: 0;
	background: var(--c-primary-light);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--f-display);
	font-weight: 600;
	font-size: 24px;
	color: var(--c-primary);
}

.author-box-info {
	flex: 1;
}

.author-box-name {
	font-family: var(--f-display);
	font-size: 18px;
	font-weight: 600;
}

.author-box-role {
	font-size: 14px;
	color: var(--c-text-secondary);
	margin-top: 2px;
}

.author-box-bio {
	margin-top: 16px;
	font-size: 15px;
	color: var(--c-text-secondary);
	line-height: 1.6;
}

.author-box-links {
	margin-top: 16px;
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.author-box-link {
	font-size: 13px;
	font-weight: 600;
	color: var(--c-text-secondary);
	padding: 5px 12px;
	border: 1px solid var(--c-border);
	border-radius: 5px;
	transition: color 0.15s, border-color 0.15s;
}

.author-box-link:hover {
	border-color: var(--c-primary);
	color: var(--c-primary);
}

.fedi-discuss {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 14px;
	font-weight: 500;
	color: var(--c-text-secondary);
	margin-top: 24px;
	padding: 8px 16px;
	border: 1px solid var(--c-border);
	border-radius: 6px;
	transition: color 0.15s, border-color 0.15s;
}

.fedi-discuss:hover {
	border-color: var(--c-primary);
	color: var(--c-primary);
}

/* =========================================================================
   Footer
   ========================================================================= */

.site-footer {
	border-top: 1px solid var(--c-border-light);
	padding: 32px 0;
}

.footer-inner {
	max-width: var(--wp--custom--width--page);
	margin: 0 auto;
	padding: 0 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}

.footer-left {
	font-size: 14px;
	color: var(--c-text-tertiary);
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}

.footer-legal {
	display: flex;
	align-items: center;
	gap: 6px;
}

.footer-legal::before {
	content: "·";
	color: var(--c-border);
}

.footer-legal ul {
	display: contents;
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-legal .menu-item {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-legal a,
.footer-legal .menu-item a {
	font-size: 14px;
	color: var(--c-text-tertiary);
}

.footer-legal a:hover,
.footer-legal .menu-item a:hover {
	color: var(--c-primary);
}

.footer-legal .menu-item + .menu-item::before {
	content: "·";
	color: var(--c-border);
	margin-right: 6px;
}

.footer-links {
	display: flex;
	align-items: center;
	gap: 16px;
	list-style: none;
}

.footer-links ul {
	display: contents;
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-links .menu-item {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-links a,
.footer-links .menu-item a {
	font-size: 14px;
	color: var(--c-text-tertiary);
}

.footer-links a:hover,
.footer-links .menu-item a:hover {
	color: var(--c-primary);
}

.footer-fedi {
	width: 100%;
	text-align: center;
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--c-border-light);
	font-size: 13px;
	color: var(--c-text-tertiary);
}

.footer-fedi code {
	font-family: var(--f-mono);
	font-size: 13px;
	background: var(--c-primary-light);
	color: var(--c-primary);
	padding: 2px 8px;
	border-radius: 3px;
}

/* =========================================================================
   Pagination
   ========================================================================= */

.pagination,
.nav-links {
	display: flex;
	justify-content: center;
	gap: 4px;
	padding: 24px 0 48px;
}

.page-numbers {
	font-family: var(--f-mono);
	font-size: 14px;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 6px;
	color: var(--c-text-secondary);
	border: 1px solid var(--c-border);
	transition: color 0.15s, border-color 0.15s;
}

.page-numbers:hover {
	border-color: var(--c-primary);
	color: var(--c-primary);
}

.page-numbers.current {
	background: var(--c-primary);
	border-color: var(--c-primary);
	color: #fff;
}

/* =========================================================================
   WordPress-specific overrides
   ========================================================================= */

/* Screen reader text */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--c-surface);
	clip: auto !important;
	clip-path: none;
	color: var(--c-text);
	display: block;
	font-size: 14px;
	font-weight: 600;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* WordPress alignments */
.alignwide {
	max-width: var(--wp--custom--width--page);
	margin-left: auto;
	margin-right: auto;
}

.alignfull {
	width: 100%;
	max-width: none;
}

.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

/* Gallery */
.wp-block-gallery {
	margin-bottom: 24px;
}

/* =========================================================================
   About Page — Block Pattern
   ========================================================================= */

.meitner-about-photo-col {
	position: sticky;
	top: 80px;
}

.meitner-about-photo img {
	aspect-ratio: 3 / 4;
	object-fit: cover;
	width: 100%;
}

.meitner-about-link {
	display: inline-block;
	font-size: 14px;
	font-weight: 600;
	color: var(--c-text-secondary);
	padding: 7px 14px;
	border: 1px solid var(--c-border);
	border-radius: 6px;
	transition: color 0.15s, border-color 0.15s;
}

.meitner-about-link:hover {
	border-color: var(--c-primary);
	color: var(--c-primary);
}

/* =========================================================================
   Now Page — Block Pattern Feed
   ========================================================================= */

.meitner-feed-items {
	list-style: none;
	padding: 0;
	margin: 0;
}

.meitner-feed-items.wp-block-post-template {
	--wp--style--block-gap: 0px;
}

.meitner-feed-items > .wp-block-post {
	list-style: none;
	margin: 0;
}

.meitner-feed-item {
	border-bottom: 1px solid var(--c-border-light);
}

.meitner-feed-item .wp-block-post-content {
	font-size: 15px;
	line-height: 1.6;
	color: var(--c-text-secondary);
}

.meitner-feed-item .wp-block-post-content p {
	margin-bottom: 0;
}

.meitner-feed-item .wp-block-post-featured-image {
	margin-top: 16px;
	border-radius: var(--radius-lg);
	overflow: hidden;
}

.meitner-feed-item .wp-block-post-featured-image img {
	width: 100%;
	height: auto;
	display: block;
}

.meitner-feed-tags {
	list-style: none;
	padding: 0;
	margin: 8px 0 0;
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}

.meitner-feed-tags a {
	font-family: var(--f-mono);
	font-size: 12px;
	color: var(--c-primary);
}

.meitner-feed-tags a::before {
	content: "#";
}

/* =========================================================================
   Responsive
   ========================================================================= */

@media (max-width: 560px) {
	.hero-inner {
		flex-direction: column;
		align-items: flex-start;
	}

	.hero-avatar {
		width: 64px;
		height: 64px;
		font-size: 26px;
	}

	.page-title {
		font-size: 26px;
	}

	.single-title {
		font-size: 26px;
	}

	.meitner-about-photo-col {
		position: static;
	}
}

/* =========================================================================
   Reduced Motion
   ========================================================================= */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}
