/* Minimal reset and base layout for Epaper Flow Pro. */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	background: #fff;
	color: #1f2933;
	font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 16px;
	line-height: 1.6;
}

img,
svg,
video,
canvas {
	display: block;
	max-width: 100%;
	height: auto;
}

button,
input,
select,
textarea {
	font: inherit;
}

a {
	color: #0f5ea8;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
}

a:hover,
a:focus {
	color: #083f73;
}

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

.screen-reader-text:focus {
	top: 1rem;
	left: 1rem;
	z-index: 100000;
	display: block;
	width: auto;
	height: auto;
	padding: 0.75rem 1rem;
	clip: auto;
	background: #fff;
	color: #111827;
	box-shadow: 0 0 0 2px #111827;
}

.site-header {
	border-bottom: 1px solid #e5e7eb;
	background: #fff;
}

.site-header__inner,
.content-wrap,
.site-footer__inner,
.site-footer__widgets {
	width: min(100% - 2rem, 1200px);
	margin-inline: auto;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	min-height: 72px;
	padding-block: 1rem;
}

.site-branding {
	min-width: 0;
}

.site-title {
	color: #111827;
	font-size: 1.25rem;
	font-weight: 700;
	text-decoration: none;
}

.site-description {
	margin: 0.15rem 0 0;
	color: #52606d;
	font-size: 0.875rem;
}

.main-navigation > ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.5rem 1rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	display: block;
	color: #1f2933;
	text-decoration: none;
}

.main-navigation a:hover,
.main-navigation a:focus {
	color: #0f5ea8;
}

.main-navigation .sub-menu,
.main-navigation .children {
	display: block;
	width: 12rem;
	margin-top: 0.5rem;
	padding: 0.5rem;
	border: 1px solid #e5e7eb;
	background: #fff;
}

.site-main {
	min-height: 55vh;
	padding-block: 2.5rem;
}

.content-entry {
	margin-bottom: 2rem;
}

.entry-header,
.archive-header {
	margin-bottom: 1.25rem;
}

.entry-title,
.archive-title {
	margin: 0;
	color: #111827;
	line-height: 1.2;
}

.entry-title a {
	color: inherit;
	text-decoration: none;
}

.entry-meta {
	margin-top: 0.5rem;
	color: #52606d;
	font-size: 0.875rem;
}

.entry-content > *:first-child {
	margin-top: 0;
}

.entry-content > *:last-child {
	margin-bottom: 0;
}

.entry-thumbnail {
	margin-bottom: 1.5rem;
}

.site-main--full-width,
.site-main--elementor-full-width,
.site-main--canvas {
	padding-block: 0;
}

.site-main--elementor-full-width .entry-content,
.site-main--canvas .entry-content {
	width: 100%;
}

.content-entry--full-width,
.elementor-full-width-content,
.canvas-content {
	width: 100%;
	margin: 0;
}

.site-footer {
	border-top: 1px solid #e5e7eb;
	background: #f8fafc;
	color: #52606d;
}

.site-footer__widgets {
	padding-block: 2rem 0;
}

.site-footer__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem 1rem;
	padding-block: 1.25rem;
	font-size: 0.9375rem;
}

.site-footer p {
	margin: 0;
}

.widget {
	margin-bottom: 1.5rem;
}

.widget-title {
	margin: 0 0 0.75rem;
	font-size: 1rem;
}

.comments-area {
	margin-top: 2.5rem;
}

.comment-list {
	padding-left: 1.25rem;
}

@media (max-width: 720px) {
	.site-header__inner {
		align-items: flex-start;
		flex-direction: column;
	}

	.main-navigation > ul {
		width: 100%;
		justify-content: flex-start;
	}

	.main-navigation .sub-menu,
	.main-navigation .children {
		width: 100%;
		margin-top: 0.25rem;
	}
}
