/*
Theme Name: Main Street
Theme URI: https://example.com/main-street
Author: The Main Street Website Company
Author URI: https://example.com
Description: A warm, classic WordPress theme inspired by small-town America between 1890 and 1910 — think old county newspapers, vintage postcards, general stores, and the historic town square. Built for businesses that want a timeless, handcrafted feel without any of the trendy trimmings.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: main-street
Tags: custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, one-column, two-columns, right-sidebar
*/

/* -------------------------------------------------------------------------
   1. CSS CUSTOM PROPERTIES
------------------------------------------------------------------------- */
:root {
	--color-bg: #f5efe3;
	--color-paper: #efe4cf;
	--color-primary: #21442d;
	--color-accent: #6b2323;
	--color-text: #2d241c;
	--color-text-light: #4a3f33;
	--color-border: #cbb997;
	--color-link: #6b2323;
	--color-link-hover: #21442d;

	--font-body: Georgia, 'Times New Roman', Times, serif;
	--font-heading: 'Palatino Linotype', 'Book Antiqua', Palatino, Georgia, serif;

	--content-max-width: 1100px;
}

/* -------------------------------------------------------------------------
   2. RESET / BASE
------------------------------------------------------------------------- */
*,
*::before,
*::after {
	box-sizing: border-box;
}

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

body {
	margin: 0;
	background-color: var(--color-bg);
	background-image:
		linear-gradient(var(--color-bg), var(--color-bg)),
		repeating-linear-gradient(
			0deg,
			rgba(45, 36, 28, 0.015),
			rgba(45, 36, 28, 0.015) 1px,
			transparent 1px,
			transparent 3px
		);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: 18px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
}

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

figure {
	margin: 0;
}

a {
	color: var(--color-link);
	text-decoration: underline;
	text-decoration-color: rgba(107, 35, 35, 0.35);
	text-underline-offset: 3px;
}

a:hover,
a:focus {
	color: var(--color-link-hover);
	text-decoration-color: currentColor;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	color: var(--color-primary);
	line-height: 1.25;
	margin: 0 0 0.55em;
	font-weight: 700;
	letter-spacing: 0.01em;
}

h1 { font-size: 2.2rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.4rem; }
h4 { font-size: 1.15rem; }

p { margin: 0 0 1.4em; }

blockquote {
	margin: 1.5em 0;
	padding: 0.3em 1.5em;
	border-left: 3px solid var(--color-accent);
	font-style: italic;
	color: var(--color-text-light);
}

hr {
	border: none;
	border-top: 1px solid var(--color-border);
	margin: 2.5em 0;
}

ul, ol {
	margin: 0 0 1.4em;
	padding-left: 1.4em;
}

table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 1.5em;
}

th, td {
	border: 1px solid var(--color-border);
	padding: 0.5em 0.75em;
	text-align: left;
}

th {
	background: var(--color-paper);
	font-family: var(--font-heading);
}

/* -------------------------------------------------------------------------
   3. LAYOUT
------------------------------------------------------------------------- */
.site {
	width: 100%;
}
.site-header-inner:empty {
    display: none;
}

.site-content {
	display: flex;
	flex-wrap: wrap;
	gap: 48px;
	padding: 40px 24px 60px;
}

#primary {
	flex: 2 1 560px;
	min-width: 0;
}

#secondary {
	flex: 1 1 260px;
	min-width: 240px;
}

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

.screen-reader-text:focus {
	position: static;
	width: auto;
	height: auto;
	margin: 0;
	padding: 1em;
	background: var(--color-paper);
	z-index: 100000;
}

/* -------------------------------------------------------------------------
   4. HEADER
------------------------------------------------------------------------- */
.site-header {
	background-color: var(--color-paper);
	border-bottom: 4px double var(--color-primary);
}

.site-header-inner {
	width: 100%;
	padding: 0;
	margin-bottom: 0px;
	text-align: center;
}

.site-branding {
	margin-bottom: 0px;
}

.custom-logo-link {
	display: inline-block;
	margin-bottom: 12px;
}

.site-title {
	font-family: var(--font-heading);
	font-size: 2.6rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin: 0;
}

.site-title a {
	color: var(--color-primary);
	text-decoration: none;
}

.site-description {
	margin: 6px 0 0;
	font-style: italic;
	color: var(--color-text-light);
	font-size: 1.05rem;
	letter-spacing: 0.02em;
}

.site-banner {
	width: 100%;
	margin: 0;
	line-height: 0;
}

.site-banner img {
	width: 100%;
	display: block;
	filter: sepia(12%) saturate(85%);
}

/* Navigation */
.main-navigation {
	background-color: var(--color-primary);
}

.main-navigation .nav-wrap {
	width: 100%;
	padding: 0 24px;
	position: relative;
}

.main-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	display: block;
	padding: 14px 18px;
	color: var(--color-bg);
	text-decoration: none;
	font-family: var(--font-heading);
	font-size: 0.95rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.main-navigation a:hover,
.main-navigation a:focus,
.main-navigation .current-menu-item > a {
	background-color: var(--color-accent);
	color: #fff;
}

.main-navigation ul ul {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background-color: var(--color-primary);
	flex-direction: column;
	z-index: 20;
	box-shadow: 0 6px 14px rgba(0, 0, 0, 0.2);
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	display: flex;
}

.main-navigation ul ul a {
	padding: 12px 18px;
}

.menu-toggle {
	display: none;
	background: var(--color-accent);
	color: #fff;
	border: none;
	font-family: var(--font-heading);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 12px 18px;
	width: 100%;
	cursor: pointer;
}

/* -------------------------------------------------------------------------
   5. POSTS / CONTENT
------------------------------------------------------------------------- */
.page-title,
.entry-title {
	font-size: 1.9rem;
}

.entry-title a {
	color: var(--color-primary);
	text-decoration: none;
}

.entry-title a:hover {
	color: var(--color-accent);
}

.entry-meta {
	font-family: var(--font-heading);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-text-light);
	margin-bottom: 1.2em;
}

.entry-meta a {
	color: var(--color-text-light);
}

.entry-meta span + span::before {
	content: "\2022";
	margin: 0 0.6em;
	color: var(--color-accent);
}

article.post,
article.page {
	background-color: var(--color-paper);
	border: 1px solid var(--color-border);
	padding: 32px 36px;
	margin-bottom: 40px;
}

article.post:last-child {
	margin-bottom: 0;
}

.post-thumbnail {
	margin-bottom: 22px;
	border: 1px solid var(--color-border);
	padding: 6px;
	background: var(--color-bg);
}

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

.entry-footer {
	margin-top: 1.6em;
	padding-top: 1em;
	border-top: 1px solid var(--color-border);
	font-family: var(--font-heading);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-text-light);
}

.entry-footer a {
	color: var(--color-text-light);
}

/* Front page: featured static page + blog section */
.front-page-notice {
	background-color: var(--color-paper);
	border: 1px dashed var(--color-border);
	padding: 22px 26px;
	margin-bottom: 40px;
	color: var(--color-text-light);
	font-style: italic;
}

.front-page-notice a {
	font-style: normal;
}

.home-blog-section {
	margin-top: 20px;
}

.home-blog-heading {
	font-size: 1.6rem;
	text-align: center;
	position: relative;
	margin-bottom: 1.2em;
	padding-bottom: 0.5em;
}

.home-blog-heading::after {
	content: "";
	display: block;
	width: 80px;
	height: 3px;
	background-color: var(--color-accent);
	margin: 0.5em auto 0;
}

.home-blog-tagline {
	text-align: center;
	font-style: italic;
	color: var(--color-text-light);
	font-size: 1.05rem;
	margin: -0.4em 0 1.6em;
}

.home-blog-pagination {
	margin-bottom: 0;
}

/* Pagination */
.pagination,
.post-navigation,
.paging-navigation {
	margin: 20px 0 40px;
	text-align: center;
	font-family: var(--font-heading);
}

.pagination .page-numbers {
	display: inline-block;
	margin: 0 4px;
	padding: 8px 14px;
	border: 1px solid var(--color-border);
	background: var(--color-paper);
	color: var(--color-primary);
	text-decoration: none;
}

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

.post-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.post-navigation a {
	text-decoration: none;
	color: var(--color-primary);
}

/* -------------------------------------------------------------------------
   6. SIDEBAR / WIDGETS
------------------------------------------------------------------------- */
.widget {
	background-color: var(--color-paper);
	border: 1px solid var(--color-border);
	padding: 24px 26px;
	margin-bottom: 30px;
}

.widget-title {
	font-size: 1.15rem;
	margin-bottom: 0.8em;
	padding-bottom: 0.5em;
	border-bottom: 2px solid var(--color-accent);
}

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

.widget li {
	padding: 6px 0;
	border-bottom: 1px dotted var(--color-border);
}

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

.widget a {
	text-decoration: none;
}

.widget a:hover {
	text-decoration: underline;
}

/* Search form */
.search-form {
	display: flex;
	gap: 8px;
}

.search-form label {
	flex: 1;
	margin: 0;
}

.search-field {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid var(--color-border);
	background: var(--color-bg);
	font-family: var(--font-body);
	color: var(--color-text);
}

.search-submit {
	padding: 10px 16px;
	background: var(--color-primary);
	color: #fff;
	border: 1px solid var(--color-primary);
	font-family: var(--font-heading);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	cursor: pointer;
}

.search-submit:hover {
	background: var(--color-accent);
	border-color: var(--color-accent);
}

/* -------------------------------------------------------------------------
   7. COMMENTS
------------------------------------------------------------------------- */
.comments-area {
	margin-top: 40px;
	padding-top: 30px;
	border-top: 3px double var(--color-primary);
}

.comment-list {
	list-style: none;
	margin: 0 0 2em;
	padding: 0;
}

.comment-list .children {
	list-style: none;
	margin: 0;
	padding-left: 40px;
}

.comment-body {
	padding: 18px 0;
	border-bottom: 1px solid var(--color-border);
}

.comment-author {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
}

.comment-metadata {
	font-size: 0.8rem;
	color: var(--color-text-light);
	margin-bottom: 0.6em;
}

.comment-metadata a {
	color: var(--color-text-light);
}

.comment-reply-link {
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.comment-respond {
	margin-top: 2em;
	background: var(--color-paper);
	border: 1px solid var(--color-border);
	padding: 24px 28px;
}

.comment-form label {
	display: block;
	font-family: var(--font-heading);
	margin-bottom: 4px;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 10px 12px;
	margin-bottom: 16px;
	border: 1px solid var(--color-border);
	background: var(--color-bg);
	font-family: var(--font-body);
	color: var(--color-text);
}

.comment-form .form-submit input {
	padding: 10px 18px;
	background: var(--color-primary);
	color: #fff;
	border: 1px solid var(--color-primary);
	font-family: var(--font-heading);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	cursor: pointer;
}

.comment-form .form-submit input:hover {
	background: var(--color-accent);
	border-color: var(--color-accent);
}

/* -------------------------------------------------------------------------
   8. FOOTER
------------------------------------------------------------------------- */
.site-footer {
	background-color: var(--color-primary);
	color: var(--color-bg);
	margin-top: 40px;
}

.footer-widgets {
	width: 100%;
	padding: 40px 24px;
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}

.footer-widgets .widget-area {
	flex: 1 1 260px;
}

.footer-widgets .widget {
	background: transparent;
	border: none;
	padding: 0;
	color: var(--color-bg);
}

.footer-widgets .widget-title {
	color: #fff;
	border-bottom-color: rgba(245, 239, 227, 0.4);
}

.footer-widgets .widget a {
	color: var(--color-bg);
}

.site-info {
	width: 100%;
	padding: 18px 24px;
	border-top: 1px solid rgba(245, 239, 227, 0.25);
	text-align: center;
	font-family: var(--font-heading);
	font-size: 0.8rem;
	letter-spacing: 0.05em;
}

.site-info a {
	color: var(--color-bg);
}

/* -------------------------------------------------------------------------
   9. MISC ELEMENTS
------------------------------------------------------------------------- */
.alignwide {
	max-width: calc(var(--content-max-width) - 100px);
}

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

.wp-caption-text,
.gallery-caption {
	font-size: 0.85rem;
	color: var(--color-text-light);
	text-align: center;
	margin-top: 0.4em;
}

.tag-links,
.cat-links {
	display: inline;
}

.error-404 .page-content {
	text-align: center;
	padding: 40px 0;
}

/* -------------------------------------------------------------------------
   10. RESPONSIVE
------------------------------------------------------------------------- */
@media (max-width: 800px) {
	.site-content {
		flex-direction: column;
		gap: 0;
	}

	#secondary {
		margin-top: 10px;
	}

	.site-header-inner {
		padding: 0;
        margin-bottom: 0;
	}

	.site-title {
		font-size: 2rem;
	}

	article.post,
	article.page {
		padding: 24px 22px;
	}

	.footer-widgets {
		padding: 30px 20px;
	}
}

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

	.main-navigation .nav-wrap {
		padding: 0;
	}

	.main-navigation ul {
		display: none;
		flex-direction: column;
	}

	.main-navigation ul.is-open {
		display: flex;
	}

	.main-navigation ul ul {
		position: static;
		box-shadow: none;
		min-width: 100%;
	}

	.main-navigation a {
		text-align: center;
	}

	body {
		font-size: 16px;
	}

	.site-title {
		font-size: 1.6rem;
	}

	.site-description {
		font-size: 0.95rem;
	}

	.site-header-inner {
		padding: 0;
        margin-bottom: 0;
	}

	article.post,
	article.page {
		padding: 20px 18px;
	}

	.entry-title,
	.page-title {
		font-size: 1.5rem;
	}

	h1 { font-size: 1.7rem; }
	h2 { font-size: 1.4rem; }
	h3 { font-size: 1.2rem; }

	.widget,
	.comment-respond {
		padding: 18px 20px;
	}

	.search-form {
		flex-direction: column;
	}

	.search-submit {
		width: 100%;
	}

	.comment-list .children {
		padding-left: 18px;
	}

	.post-navigation .nav-links {
		flex-direction: column;
		gap: 10px;
	}

	.home-blog-heading {
		font-size: 1.35rem;
	}

	/* Tables can be wider than the screen; let them scroll instead of
	   breaking the layout. */
	.entry-content table {
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
}

@media (max-width: 400px) {
	.site-title {
		font-size: 1.4rem;
	}

	.footer-widgets {
		flex-direction: column;
	}
}

