/*
Theme Name: Made Up News
Theme URI: https://madeupnews.co.uk
Author: Made Up News
Author URI: https://madeupnews.co.uk
Description: A bespoke broadsheet-style theme for British satirical news. Built for speed, readability, and editorial gravitas. Fully compatible with Rank Math, AdSense, and Google News. No bloat, no page builders, just newspaper.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: made-up-news
Tags: news, magazine, blog, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, two-columns, right-sidebar
*/

/* ===========================
   FONTS
   =========================== */

@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,600;0,8..60,700;0,8..60,900;1,8..60,400;1,8..60,700&family=Inter:wght@400;500;600;700&display=swap');

/* ===========================
   CSS VARIABLES
   =========================== */

:root {
	--colour-ink: #111111;
	--colour-paper: #faf8f3;
	--colour-paper-pure: #ffffff;
	--colour-rule: #111111;
	--colour-muted: #6b6b6b;
	--colour-accent: #b8261c;
	--colour-link: #b8261c;
	--colour-link-hover: #111111;
	--colour-tag-bg: #111111;
	--colour-tag-fg: #faf8f3;

	--font-display: 'Source Serif 4', Georgia, serif;
	--font-body: 'Source Serif 4', Georgia, serif;
	--font-meta: 'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Arial, sans-serif;

	--max-width: 1240px;
	--gutter: clamp(1rem, 3vw, 2.5rem);

	--rule-thin: 1px solid var(--colour-rule);
	--rule-thick: 3px solid var(--colour-rule);
	--rule-double: 3px double var(--colour-rule);
}

/* ===========================
   RESET & BASE
   =========================== */

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

html {
	font-size: 17px;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--colour-ink);
	background: var(--colour-paper);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: 'kern' 1, 'liga' 1, 'onum' 1;
}

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

a {
	color: var(--colour-link);
	text-decoration: none;
	transition: color 0.15s ease;
	-webkit-tap-highlight-color: rgba(17, 17, 17, 0.08);
}

a:hover,
a:focus {
	color: var(--colour-link-hover);
	text-decoration: underline;
	text-underline-offset: 3px;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 0.5em;
	color: var(--colour-ink);
	letter-spacing: -0.005em;
}

p {
	margin: 0 0 1em;
}

p:last-child {
	margin-bottom: 0;
}

blockquote {
	margin: 1.5em 0;
	padding: 0 0 0 1.25rem;
	border-left: 3px solid var(--colour-accent);
	font-style: italic;
	font-size: 1.1rem;
	color: var(--colour-ink);
}

hr {
	border: 0;
	border-top: var(--rule-thick);
	margin: 2rem 0;
}

/* ===========================
   LAYOUT WRAPPER
   =========================== */

.mun-wrap {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--gutter);
}

.mun-main {
	padding: 2rem 0 4rem;
}

/* ===========================
   MASTHEAD
   =========================== */

.mun-masthead {
	border-bottom: var(--rule-thick);
	padding: 1.25rem 0 1rem;
	background: var(--colour-paper);
}

.mun-masthead-top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: var(--font-meta);
	font-size: 0.7rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--colour-muted);
	padding-bottom: 0.5rem;
	border-bottom: var(--rule-thin);
	margin-bottom: 1rem;
}

.mun-masthead-date {
	font-weight: 500;
}

.mun-masthead-tagline {
	font-style: italic;
	letter-spacing: 0.02em;
	text-transform: none;
}

.mun-masthead-title {
	font-family: var(--font-display);
	font-weight: 900;
	font-size: clamp(2.25rem, 7vw, 4.75rem);
	line-height: 0.95;
	letter-spacing: -0.025em;
	text-align: center;
	margin: 0;
	text-transform: none;
}

.mun-masthead-title a {
	color: var(--colour-ink);
	text-decoration: none;
}

.mun-masthead-title a:hover {
	text-decoration: none;
	color: var(--colour-ink);
}

.mun-masthead-logo img {
	max-height: 110px;
	width: auto;
	margin: 0 auto;
}

.mun-masthead-subtitle {
	font-family: var(--font-body);
	font-style: italic;
	font-weight: 400;
	font-size: 1rem;
	text-align: center;
	color: var(--colour-muted);
	margin: 0.25rem 0 0;
}

/* ===========================
   NAVIGATION
   =========================== */

.mun-nav {
	border-bottom: var(--rule-thick);
	background: var(--colour-paper);
	font-family: var(--font-meta);
}

.mun-nav-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}

.mun-nav-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
}

.mun-nav-menu li {
	margin: 0;
}

.mun-nav-menu a {
	display: block;
	padding: 0.5rem 0.9rem;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--colour-ink);
	text-decoration: none;
}

.mun-nav-menu a:hover,
.mun-nav-menu .current-menu-item a {
	background: var(--colour-ink);
	color: var(--colour-paper);
}

.mun-nav-search {
	margin-left: auto;
}

.mun-search-form {
	display: flex;
	align-items: center;
	gap: 0;
}

.mun-search-form input[type="search"] {
	border: var(--rule-thin);
	background: var(--colour-paper);
	padding: 0.4rem 0.6rem;
	font-family: var(--font-meta);
	font-size: 0.8rem;
	width: 160px;
}

.mun-search-form button {
	background: var(--colour-accent);
	color: var(--colour-paper);
	border: var(--rule-thin);
	border-left: 0;
	border-color: var(--colour-accent);
	padding: 0.4rem 0.7rem;
	font-family: var(--font-meta);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.15s ease;
}

.mun-search-form button:hover {
	background: var(--colour-ink);
	border-color: var(--colour-ink);
}

/* Mobile nav toggle */
.mun-nav-toggle {
	display: none;
	background: var(--colour-accent);
	color: var(--colour-paper);
	border: 0;
	padding: 0.5rem 0.9rem;
	font-family: var(--font-meta);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.15s ease;
}

.mun-nav-toggle:hover {
	background: var(--colour-ink);
}

/* Mobile/tablet nav toggle */
@media (max-width: 1024px) {
	.mun-nav-toggle {
		display: block;
	}
	.mun-nav-menu {
		flex-direction: column;
		width: 100%;
		display: none;
	}
	.mun-nav-menu.is-open {
		display: flex;
	}
	.mun-nav-menu a {
		border-bottom: var(--rule-thin);
	}
	.mun-nav-search {
		width: 100%;
		margin: 0;
		display: none;
	}
	.mun-nav-search.is-open {
		display: block;
	}
	.mun-search-form input[type="search"] {
		flex: 1;
		width: auto;
	}
	.mun-nav-inner {
		flex-wrap: wrap;
	}
}

/* ===========================
   HOMEPAGE / ARCHIVE GRID
   =========================== */

.mun-grid {
	display: grid;
	grid-template-columns: 1fr 280px;
	gap: 2.5rem;
}

@media (max-width: 960px) {
	.mun-grid {
		grid-template-columns: 1fr;
	}
}

.mun-content {
	min-width: 0;
}

/* Lead story */
.mun-lead {
	border-bottom: var(--rule-thick);
	padding-bottom: 2rem;
	margin-bottom: 2rem;
}

.mun-lead-image {
	margin: 0 0 1.25rem;
	overflow: hidden;
}

.mun-lead-image img {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}

.mun-lead .mun-category-tag {
	margin-bottom: 0.75rem;
}

.mun-lead-title {
	font-size: clamp(1.75rem, 4.5vw, 3rem);
	line-height: 1.05;
	letter-spacing: -0.01em;
	margin: 0 0 0.75rem;
}

.mun-lead-title a,
.mun-lead-title a:link,
.mun-lead-title a:visited {
	color: var(--colour-ink);
}

.mun-lead-title a:hover,
.mun-lead-title a:focus {
	text-decoration: none;
	color: var(--colour-accent);
}

.mun-lead-excerpt {
	font-size: 1.1rem;
	line-height: 1.5;
	color: var(--colour-ink);
	max-width: 60ch;
	margin-bottom: 0.75rem;
}

/* Secondary stories grid */
.mun-stories {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
	margin-bottom: 2rem;
}

@media (max-width: 600px) {
	.mun-stories {
		grid-template-columns: 1fr;
		gap: 1.75rem;
	}
}

.mun-story {
	display: flex;
	flex-direction: column;
	border-top: var(--rule-thin);
	padding-top: 1rem;
}

.mun-story-image {
	margin: 0 0 0.75rem;
	overflow: hidden;
}

.mun-story-image img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.mun-story-title {
	font-size: 1.35rem;
	line-height: 1.2;
	margin: 0 0 0.5rem;
}

.mun-story-title a,
.mun-story-title a:link,
.mun-story-title a:visited {
	color: var(--colour-ink);
}

.mun-story-title a:hover,
.mun-story-title a:focus {
	color: var(--colour-accent);
	text-decoration: none;
}

.mun-story-excerpt {
	font-size: 0.95rem;
	color: var(--colour-muted);
	margin-bottom: 0.5rem;
}

/* Meta info */
.mun-meta {
	font-family: var(--font-meta);
	font-size: 0.7rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--colour-muted);
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
}

.mun-meta a {
	color: var(--colour-muted);
}

.mun-meta a:hover {
	color: var(--colour-ink);
	text-decoration: none;
}

.mun-meta-separator {
	opacity: 0.4;
}

/* Category tag */
.mun-category-tag {
	display: inline-block;
	background: var(--colour-accent);
	color: var(--colour-tag-fg);
	font-family: var(--font-meta);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.25rem 0.6rem;
	text-decoration: none;
}

.mun-category-tag:hover {
	background: var(--colour-ink);
	color: var(--colour-paper);
	text-decoration: none;
}

/* ===========================
   SINGLE ARTICLE
   =========================== */

.mun-article {
	max-width: 100%;
	margin: 0;
}

.mun-article-header {
	border-bottom: var(--rule-thin);
	padding-bottom: 1.5rem;
	margin-bottom: 1.5rem;
}

.mun-article-header .mun-category-tag {
	margin-bottom: 1rem;
}

.mun-article-title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	line-height: 1.05;
	letter-spacing: -0.01em;
	margin: 0 0 1rem;
}

.mun-article-subtitle {
	font-family: var(--font-display);
	font-style: italic;
	font-weight: 400;
	font-size: 1.25rem;
	color: var(--colour-muted);
	line-height: 1.4;
	margin: 0 0 1.25rem;
	max-width: 60ch;
}

.mun-byline {
	font-family: var(--font-meta);
	font-size: 0.85rem;
	color: var(--colour-ink);
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
}

.mun-byline-by {
	color: var(--colour-muted);
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.mun-byline-author a {
	color: var(--colour-ink);
	font-weight: 600;
	text-decoration: none;
	border-bottom: 1px dotted var(--colour-ink);
}

.mun-byline-author a:hover {
	color: var(--colour-accent);
	border-bottom-color: var(--colour-accent);
}

.mun-byline-date {
	color: var(--colour-muted);
	font-size: 0.75rem;
	letter-spacing: 0.04em;
}

.mun-article-image {
	margin: 0 0 1.5rem;
}

.mun-article-image img {
	width: 100%;
	height: auto;
}

.mun-article-image figcaption {
	font-family: var(--font-meta);
	font-size: 0.8rem;
	color: var(--colour-muted);
	margin-top: 0.5rem;
	padding-top: 0.5rem;
	border-top: var(--rule-thin);
	font-style: italic;
}

.mun-article-body {
	font-size: 1.125rem;
	line-height: 1.7;
}

.mun-article-body > p:first-of-type::first-letter {
	font-family: var(--font-display);
	font-weight: 700;
	float: left;
	font-size: 3.75rem;
	line-height: 0.9;
	margin: 0.25rem 0.5rem 0 0;
	color: var(--colour-ink);
}

.mun-article-body h2 {
	font-size: 1.75rem;
	margin: 2rem 0 0.75rem;
	line-height: 1.2;
}

.mun-article-body h3 {
	font-size: 1.35rem;
	margin: 1.75rem 0 0.5rem;
}

.mun-article-body p {
	margin: 0 0 1.25rem;
}

.mun-article-body img {
	margin: 1.5rem 0;
}

.mun-article-body ul,
.mun-article-body ol {
	padding-left: 1.5rem;
	margin: 0 0 1.25rem;
}

.mun-article-body li {
	margin-bottom: 0.5rem;
}

.mun-article-body code {
	background: rgba(0, 0, 0, 0.05);
	padding: 0.1rem 0.35rem;
	font-family: ui-monospace, SFMono-Regular, monospace;
	font-size: 0.9em;
}

.mun-article-body pre {
	background: var(--colour-ink);
	color: var(--colour-paper);
	padding: 1rem;
	overflow-x: auto;
	font-family: ui-monospace, SFMono-Regular, monospace;
	font-size: 0.85rem;
	line-height: 1.5;
}

/* Author bio at end of article */
.mun-author-bio {
	border-top: var(--rule-thick);
	border-bottom: var(--rule-thick);
	padding: 1.5rem 0;
	margin: 3rem 0 2rem;
	display: flex;
	gap: 1.25rem;
	align-items: flex-start;
}

.mun-author-bio-avatar img {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	object-fit: cover;
}

.mun-author-bio-text {
	flex: 1;
	min-width: 0;
}

.mun-author-bio-label {
	font-family: var(--font-meta);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--colour-muted);
	margin: 0 0 0.25rem;
}

.mun-author-bio-name {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	line-height: 1.1;
}

.mun-author-bio-name a {
	color: var(--colour-ink);
}

.mun-author-bio-name a:hover {
	color: var(--colour-accent);
	text-decoration: none;
}

.mun-author-bio-description {
	font-size: 0.95rem;
	color: var(--colour-ink);
	line-height: 1.5;
	margin: 0;
}

/* Related articles */
.mun-related {
	margin: 2rem 0;
	padding-top: 1.5rem;
}

.mun-related-heading {
	font-family: var(--font-meta);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--colour-muted);
	padding-bottom: 0.5rem;
	border-bottom: var(--rule-thin);
	margin: 0 0 1.25rem;
}

.mun-related-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

@media (max-width: 720px) {
	.mun-related-list {
		grid-template-columns: 1fr;
	}
}

.mun-related-item-title {
	font-size: 1.1rem;
	line-height: 1.25;
	margin: 0.5rem 0 0.25rem;
}

.mun-related-item-title a,
.mun-related-item-title a:link,
.mun-related-item-title a:visited {
	color: var(--colour-ink);
}

.mun-related-item-title a:hover,
.mun-related-item-title a:focus {
	color: var(--colour-accent);
	text-decoration: none;
}

/* ===========================
   SIDEBAR
   =========================== */

.mun-sidebar {
	font-size: 0.95rem;
}

@media (max-width: 960px) {
	.mun-sidebar {
		border-top: var(--rule-thick);
		padding-top: 2rem;
		margin-top: 2rem;
	}
}

.mun-widget {
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: var(--rule-thin);
}

.mun-widget:last-child {
	border-bottom: 0;
}

.mun-widget-title {
	font-family: var(--font-meta);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin: 0 0 1rem;
	padding-bottom: 0.5rem;
	border-bottom: var(--rule-thick);
}

.mun-widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mun-widget li {
	padding: 0.5rem 0;
	border-bottom: var(--rule-thin);
	font-size: 0.95rem;
}

.mun-widget li:last-child {
	border-bottom: 0;
}

.mun-widget a {
	color: var(--colour-ink);
}

.mun-widget a:hover {
	color: var(--colour-accent);
	text-decoration: none;
}

/* ===========================
   ARCHIVE / SEARCH
   =========================== */

.mun-archive-header {
	border-bottom: var(--rule-thick);
	padding-bottom: 1.25rem;
	margin-bottom: 2rem;
}

.mun-archive-label {
	font-family: var(--font-meta);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--colour-muted);
	margin: 0 0 0.25rem;
}

.mun-archive-title {
	font-size: clamp(2rem, 5vw, 3rem);
	margin: 0 0 0.5rem;
	line-height: 1.05;
}

.mun-archive-description {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.1rem;
	color: var(--colour-muted);
	margin: 0;
	max-width: 65ch;
}

/* Author archive header */
.mun-author-header {
	display: flex;
	gap: 1.5rem;
	align-items: flex-start;
	border-bottom: var(--rule-thick);
	padding-bottom: 1.5rem;
	margin-bottom: 2rem;
}

.mun-author-header-avatar img {
	width: 96px;
	height: 96px;
	border-radius: 50%;
	object-fit: cover;
}

.mun-author-header-info {
	flex: 1;
	min-width: 0;
}

/* ===========================
   PAGINATION
   =========================== */

.mun-pagination {
	margin: 2rem 0;
	padding-top: 1.5rem;
	border-top: var(--rule-thin);
	font-family: var(--font-meta);
	font-size: 0.85rem;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.25rem;
}

.mun-pagination a,
.mun-pagination .current {
	display: inline-block;
	padding: 0.4rem 0.75rem;
	border: var(--rule-thin);
	color: var(--colour-ink);
	text-decoration: none;
	letter-spacing: 0.04em;
}

.mun-pagination a:hover {
	background: var(--colour-ink);
	color: var(--colour-paper);
}

.mun-pagination .current {
	background: var(--colour-accent);
	color: var(--colour-paper);
	border-color: var(--colour-accent);
}

.mun-pagination .dots {
	padding: 0.4rem 0.5rem;
	color: var(--colour-muted);
}

/* ===========================
   PAGE (static)
   =========================== */

.mun-page {
	max-width: 720px;
	margin: 0 auto;
}

.mun-page-title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	line-height: 1.05;
	margin: 0 0 1.5rem;
	border-bottom: var(--rule-thick);
	padding-bottom: 1rem;
}

.mun-page-content {
	font-size: 1.05rem;
	line-height: 1.7;
}

.mun-page-content h2 {
	font-size: 1.75rem;
	margin: 2rem 0 0.75rem;
}

.mun-page-content h3 {
	font-size: 1.3rem;
	margin: 1.5rem 0 0.5rem;
}

/* ===========================
   COMMENTS
   =========================== */

.mun-comments {
	margin: 3rem 0 2rem;
	padding-top: 1.5rem;
	border-top: var(--rule-thick);
}

.mun-comments-title {
	font-size: 1.75rem;
	margin: 0 0 1.5rem;
}

.mun-comment {
	padding: 1.25rem 0;
	border-bottom: var(--rule-thin);
}

.mun-comment-author {
	font-family: var(--font-meta);
	font-weight: 600;
	font-size: 0.9rem;
}

.mun-comment-date {
	font-family: var(--font-meta);
	font-size: 0.75rem;
	color: var(--colour-muted);
	margin-left: 0.5rem;
}

.mun-comment-body {
	margin-top: 0.5rem;
}

.mun-comment-form input[type="text"],
.mun-comment-form input[type="email"],
.mun-comment-form input[type="url"],
.mun-comment-form textarea {
	width: 100%;
	border: var(--rule-thin);
	background: var(--colour-paper-pure);
	padding: 0.6rem;
	font-family: var(--font-body);
	font-size: 1rem;
	margin-bottom: 0.75rem;
}

.mun-comment-form textarea {
	min-height: 140px;
}

.mun-comment-form label {
	display: block;
	font-family: var(--font-meta);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-bottom: 0.25rem;
}

.mun-comment-form .submit {
	background: var(--colour-accent);
	color: var(--colour-paper);
	border: 0;
	padding: 0.7rem 1.5rem;
	font-family: var(--font-meta);
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.15s ease;
}

.mun-comment-form .submit:hover {
	background: var(--colour-ink);
}

/* ===========================
   FOOTER
   =========================== */

.mun-footer {
	border-top: var(--rule-thick);
	background: var(--colour-ink);
	color: var(--colour-paper);
	padding: 2.5rem 0 1.5rem;
	margin-top: 4rem;
}

.mun-footer a {
	color: var(--colour-paper);
}

.mun-footer a:hover {
	color: var(--colour-paper);
	text-decoration: underline;
}

.mun-footer-widgets {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid rgba(250, 248, 243, 0.2);
	margin-bottom: 1.5rem;
}

@media (max-width: 720px) {
	.mun-footer-widgets {
		grid-template-columns: 1fr;
	}
}

.mun-footer .mun-widget {
	border: 0;
	margin: 0;
	padding: 0;
}

.mun-footer .mun-widget-title {
	color: var(--colour-paper);
	border-bottom-color: var(--colour-paper);
}

.mun-footer .mun-widget li {
	border-bottom-color: rgba(250, 248, 243, 0.15);
}

.mun-footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
	font-family: var(--font-meta);
	font-size: 0.8rem;
}

.mun-footer-credit {
	color: rgba(250, 248, 243, 0.7);
}

/* ===========================
   ADSENSE / AD ZONES
   =========================== */

.mun-ad-zone {
	margin: 1.5rem 0;
	padding: 0.5rem;
	min-height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mun-ad-zone-inline {
	border-top: var(--rule-thin);
	border-bottom: var(--rule-thin);
	margin: 2rem 0;
	padding: 1rem 0;
}

.mun-ad-zone-label {
	font-family: var(--font-meta);
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--colour-muted);
	text-align: center;
	margin-bottom: 0.5rem;
}

/* ===========================
   404
   =========================== */

.mun-404 {
	text-align: center;
	padding: 4rem 0;
	max-width: 600px;
	margin: 0 auto;
}

.mun-404-number {
	font-family: var(--font-display);
	font-weight: 900;
	font-size: clamp(6rem, 20vw, 12rem);
	line-height: 0.85;
	margin: 0;
	color: var(--colour-accent);
}

.mun-404-title {
	font-size: 2rem;
	margin: 0.5rem 0 1rem;
}

.mun-404-text {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.2rem;
	color: var(--colour-muted);
	margin-bottom: 2rem;
}

/* ===========================
   UTILITY
   =========================== */

.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;
}

.alignleft {
	float: left;
	margin: 0 1.5rem 1rem 0;
}

.alignright {
	float: right;
	margin: 0 0 1rem 1.5rem;
}

.aligncenter {
	display: block;
	margin: 1rem auto;
}

.wp-caption-text,
figcaption {
	font-family: var(--font-meta);
	font-size: 0.8rem;
	color: var(--colour-muted);
	font-style: italic;
	margin-top: 0.5rem;
}

/* Print styles */
@media print {
	.mun-masthead,
	.mun-nav,
	.mun-sidebar,
	.mun-footer,
	.mun-ad-zone {
		display: none;
	}
	.mun-article {
		max-width: 100%;
	}
}

/* Very narrow phones */
@media (max-width: 480px) {
	.mun-masthead {
		padding: 0.75rem 0 0.5rem;
	}
	.mun-masthead-top {
		font-size: 0.65rem;
		padding-bottom: 0.4rem;
		margin-bottom: 0.6rem;
	}
	.mun-masthead-subtitle {
		font-size: 0.9rem;
	}
	.mun-main {
		padding: 1.25rem 0 2.5rem;
	}
	.mun-lead {
		padding-bottom: 1.5rem;
		margin-bottom: 1.5rem;
	}
	.mun-article-header {
		padding-bottom: 1rem;
		margin-bottom: 1rem;
	}
	.mun-stories {
		gap: 1.5rem;
	}
	.mun-search-form button,
	.mun-nav-toggle,
	.mun-comment-form .submit {
		padding: 0.6rem 1rem;
		min-height: 44px;
	}
	.mun-nav-menu a {
		padding: 0.75rem 0.9rem;
		min-height: 44px;
	}
}
