/*
Theme Name: Compatible Creatures
Theme URI: https://bruce.maulden.us/
Description: A clean, fast, mobile-first editorial theme for Compatible Creatures, the longform writing of Bruce Maulden. Keeps the original Leaf identity (Oswald headings, PT Sans body, red accent, dark footer, content-forward column with a collapsing sidebar) and rebuilds the foundation to modern standards: responsive, accessible, lightweight, and friendly to an SEO plugin which owns titles, meta, and structured data.
Author: Metzae Media
Author URI: https://metzae.net/
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: compatible-creatures
Tags: blog, news, editorial, two-columns, right-sidebar, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* =============================================================================
   Design tokens
   ----------------------------------------------------------------------------
   Carries the original identity: Oswald headings, PT Sans body, #C4302B red.
   ========================================================================== */
:root {
	--cc-text:        #2b2b2b;          /* darker than the old #555 for contrast */
	--cc-text-soft:   #555;
	--cc-meta:        #777;
	--cc-accent:      #c4302b;          /* the original red */
	--cc-accent-dark: #9e211d;
	--cc-bg:          #ffffff;
	--cc-bg-soft:     #f5f4f2;
	--cc-border:      #e3e1dd;
	--cc-footer-bg:   #303030;          /* the original dark footer */
	--cc-footer-text: #cfcdc9;

	--cc-font-body:    'PT Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
	--cc-font-heading: 'Oswald', 'Helvetica Neue', Helvetica, Arial, sans-serif;

	--cc-measure:   38rem;              /* comfortable longform line length */
	--cc-wrap:      1080px;             /* outer max-width */
	--cc-gap:       clamp(1rem, 4vw, 2.5rem);

	--cc-radius:    4px;
}

/* =============================================================================
   Reset / base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }

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

body {
	margin: 0;
	background: var(--cc-bg);
	color: var(--cc-text);
	font-family: var(--cc-font-body);
	font-size: 1.125rem;               /* ~18px, up from the old 14px */
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

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

a {
	color: var(--cc-accent);
	text-decoration: none;
}
a:hover, a:focus { color: var(--cc-accent-dark); text-decoration: underline; }

/* Visible keyboard focus everywhere */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline: 3px solid var(--cc-accent);
	outline-offset: 2px;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--cc-font-heading);
	font-weight: 600;
	line-height: 1.15;
	color: #1c1c1c;
	margin: 0 0 0.5em;
	letter-spacing: 0.01em;
}

p, ul, ol, blockquote, figure, table, pre { margin: 0 0 1.25em; }

blockquote {
	margin-inline: 0;
	padding: 0.25rem 0 0.25rem 1.25rem;
	border-left: 4px solid var(--cc-accent);
	color: var(--cc-text-soft);
	font-style: italic;
}
blockquote cite { font-style: normal; color: var(--cc-meta); }

code, pre, kbd, samp { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
pre { overflow-x: auto; background: var(--cc-bg-soft); padding: 1rem; border-radius: var(--cc-radius); font-size: 0.9em; }

hr { border: 0; border-top: 1px solid var(--cc-border); margin: 2rem 0; }

/* =============================================================================
   Layout
   ========================================================================== */
.cc-wrap {
	width: 100%;
	max-width: var(--cc-wrap);
	margin-inline: auto;
	padding-inline: var(--cc-gap);
}

.site-content {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	padding-block: 1.75rem 2.5rem;
}

/* Two columns once there is room for them */
@media (min-width: 60em) {
	.site-content {
		grid-template-columns: minmax(0, 1fr) 18rem;
		gap: 3rem;
		padding-block: 2.5rem 3.5rem;
	}
	body.no-sidebar .site-content { grid-template-columns: minmax(0, 1fr); }
}

/* =============================================================================
   Skip link (accessibility)
   ========================================================================== */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	background: #1c1c1c;
	color: #fff;
	padding: 0.6rem 1rem;
	z-index: 1000;
}
.skip-link:focus { left: 0; }

/* =============================================================================
   Header
   ========================================================================== */
.site-header {
	border-bottom: 3px solid var(--cc-accent);
	background: var(--cc-bg);
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-block: 1rem;
}
.site-branding { min-width: 0; }
.site-title {
	font-size: clamp(1.6rem, 5vw, 2.6rem);
	margin: 0;
	line-height: 1;
	text-transform: uppercase;
}
.site-title a { color: #1c1c1c; }
.site-title a:hover, .site-title a:focus { color: var(--cc-accent); text-decoration: none; }
.site-description {
	font-family: var(--cc-font-body);
	font-size: 0.95rem;
	font-weight: 400;
	color: var(--cc-meta);
	margin: 0.35rem 0 0;
	font-style: italic;
}

/* =============================================================================
   Navigation
   ========================================================================== */
.menu-toggle {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: #1c1c1c;
	color: #fff;
	border: 0;
	font-family: var(--cc-font-heading);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.95rem;
	padding: 0.55rem 0.9rem;
	border-radius: var(--cc-radius);
	cursor: pointer;
}
.menu-toggle__bar { display: inline-block; width: 18px; height: 2px; background: #fff; position: relative; }
.menu-toggle__bar::before,
.menu-toggle__bar::after { content: ""; position: absolute; left: 0; width: 18px; height: 2px; background: #fff; }
.menu-toggle__bar::before { top: -5px; }
.menu-toggle__bar::after { top: 5px; }

.main-navigation { background: #1c1c1c; }
.main-navigation .cc-wrap { padding-block: 0; }

.main-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.main-navigation a {
	display: block;
	color: #fff;
	font-family: var(--cc-font-heading);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-size: 0.98rem;
	padding: 0.8rem 0.9rem;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
.main-navigation a:hover,
.main-navigation a:focus,
.main-navigation .current-menu-item > a { background: var(--cc-accent); color: #fff; text-decoration: none; }

/* Collapsed by default on mobile; toggled open with JS */
.main-navigation .menu { display: none; }
.main-navigation.toggled .menu { display: block; }

@media (min-width: 48em) {
	.menu-toggle { display: none; }
	.main-navigation .menu { display: flex !important; flex-wrap: wrap; }
	.main-navigation a { border-bottom: 0; }
	/* simple dropdowns */
	.main-navigation li { position: relative; }
	.main-navigation .sub-menu {
		position: absolute;
		left: 0; top: 100%;
		min-width: 12rem;
		background: #1c1c1c;
		display: none;
		z-index: 50;
	}
	.main-navigation li:hover > .sub-menu,
	.main-navigation li:focus-within > .sub-menu { display: block; }
}

/* =============================================================================
   Posts list (index / archive / search)
   ========================================================================== */
.page-header { margin-bottom: 1.5rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--cc-border); }
.page-title { font-size: clamp(1.4rem, 4vw, 2rem); margin: 0; }
.page-title .label { color: var(--cc-meta); font-weight: 400; }

.post-card {
	display: grid;
	gap: 1rem;
	padding-bottom: 1.75rem;
	margin-bottom: 1.75rem;
	border-bottom: 1px solid var(--cc-border);
}
@media (min-width: 34em) {
	.post-card.has-thumb { grid-template-columns: 200px 1fr; }
}
.post-card__thumb img { border-radius: var(--cc-radius); width: 100%; object-fit: cover; }
.post-card__title { font-size: 1.55rem; margin: 0 0 0.35rem; }
.post-card__title a { color: #1c1c1c; }
.post-card__title a:hover, .post-card__title a:focus { color: var(--cc-accent); text-decoration: none; }
.post-card__excerpt { color: var(--cc-text-soft); }

.entry-meta {
	font-family: var(--cc-font-heading);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-size: 0.78rem;
	color: var(--cc-meta);
	margin-bottom: 0.4rem;
}
.entry-meta a { color: var(--cc-meta); }
.entry-meta a:hover, .entry-meta a:focus { color: var(--cc-accent); }
.entry-meta > * + *::before { content: "\00a0\00b7\00a0"; color: var(--cc-border); }

.read-more {
	display: inline-block;
	font-family: var(--cc-font-heading);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.85rem;
	color: var(--cc-accent);
}
.read-more::after { content: " \2192"; }

/* =============================================================================
   Single post / page
   ========================================================================== */
.entry-header { margin-bottom: 1.25rem; }
.entry-title { font-size: clamp(1.8rem, 5vw, 2.8rem); }
.entry-featured { margin: 0 0 1.5rem; }
.entry-featured img { width: 100%; border-radius: var(--cc-radius); }

.entry-content { max-width: var(--cc-measure); }
.entry-content > * { max-width: 100%; }
.entry-content h2 { font-size: 1.6rem; margin-top: 1.8rem; }
.entry-content h3 { font-size: 1.3rem; margin-top: 1.5rem; }
.entry-content a { text-decoration: underline; text-underline-offset: 2px; }
.entry-content figure figcaption { font-size: 0.85rem; color: var(--cc-meta); text-align: center; margin-top: 0.4rem; }
.entry-content img { border-radius: var(--cc-radius); }

/* Wide / full alignment support for the block editor */
.alignwide  { width: min(100%, 52rem); margin-inline: auto; }
.alignfull  { width: 100%; }
.aligncenter { margin-inline: auto; }
.alignleft  { float: left;  margin: 0.25rem 1.5rem 1rem 0; }
.alignright { float: right; margin: 0.25rem 0 1rem 1.5rem; }

.entry-footer {
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid var(--cc-border);
	font-size: 0.9rem;
	color: var(--cc-meta);
}
.entry-footer .cat-links,
.entry-footer .tags-links { display: block; margin-bottom: 0.4rem; }

.post-navigation { margin: 2.5rem 0; display: grid; gap: 1rem; }
@media (min-width: 40em) { .post-navigation .nav-links { display: flex; justify-content: space-between; gap: 1rem; } }
.post-navigation a { display: block; }
.post-navigation .meta-nav { display: block; font-family: var(--cc-font-heading); text-transform: uppercase; font-size: 0.75rem; color: var(--cc-meta); }

/* Author bio */
.author-bio {
	display: grid;
	gap: 1rem;
	grid-template-columns: 64px 1fr;
	align-items: start;
	background: var(--cc-bg-soft);
	padding: 1.25rem;
	border-radius: var(--cc-radius);
	margin: 2rem 0;
}
.author-bio img { border-radius: 50%; }
.author-bio__name { margin: 0 0 0.25rem; font-size: 1.1rem; }

/* =============================================================================
   Embeds: force 16/9 (Covenant WordPress baseline)
   ========================================================================== */
.entry-content iframe[src*="youtube.com"],
.entry-content iframe[src*="youtube-nocookie.com"],
.entry-content iframe[src*="vimeo.com"],
.wp-block-embed__wrapper iframe {
	aspect-ratio: 16 / 9;
	width: 100%;
	height: auto;
}

/* =============================================================================
   Comments
   ========================================================================== */
.comments-area { margin-top: 2.5rem; }
.comments-title, .comment-reply-title { font-size: 1.4rem; }
.comment-list { list-style: none; margin: 0; padding: 0; }
.comment-list ol { list-style: none; }
.comment-list .children { margin-left: 1.25rem; padding-left: 1.25rem; border-left: 1px solid var(--cc-border); }
.comment-body { padding: 1rem 0; border-bottom: 1px solid var(--cc-border); }
.comment-author { font-family: var(--cc-font-heading); }
.comment-author .avatar { border-radius: 50%; vertical-align: middle; margin-right: 0.5rem; }
.comment-metadata { font-size: 0.8rem; color: var(--cc-meta); }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea,
.search-field {
	width: 100%;
	max-width: 100%;
	padding: 0.6rem 0.7rem;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius);
	font: inherit;
	font-size: 1rem;
	background: #fff;
}
.comment-form textarea { min-height: 8rem; }

/* =============================================================================
   Buttons
   ========================================================================== */
.button,
button,
input[type="submit"],
.comment-form input[type="submit"] {
	display: inline-block;
	background: var(--cc-accent);
	color: #fff;
	border: 0;
	font-family: var(--cc-font-heading);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.95rem;
	padding: 0.6rem 1.2rem;
	border-radius: var(--cc-radius);
	cursor: pointer;
}
.button:hover, button:hover, input[type="submit"]:hover { background: var(--cc-accent-dark); color: #fff; text-decoration: none; }

/* =============================================================================
   Sidebar / widgets
   ========================================================================== */
.widget-area { display: grid; gap: 1.75rem; align-content: start; }
.widget { font-size: 0.98rem; }
.widget-title {
	font-size: 1.05rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin: 0 0 0.75rem;
	padding-bottom: 0.4rem;
	border-bottom: 2px solid var(--cc-accent);
}
.widget ul { list-style: none; margin: 0; padding: 0; }
.widget li { padding: 0.35rem 0; border-bottom: 1px solid var(--cc-border); }
.widget li:last-child { border-bottom: 0; }
.tagcloud a {
	display: inline-block;
	background: var(--cc-bg-soft);
	color: var(--cc-text-soft);
	padding: 0.2rem 0.55rem;
	margin: 0 0.25rem 0.4rem 0;
	border-radius: var(--cc-radius);
	font-size: 0.85rem !important;
}
.tagcloud a:hover { background: var(--cc-accent); color: #fff; text-decoration: none; }

/* =============================================================================
   Pagination
   ========================================================================== */
.pagination { margin: 2rem 0; }
.pagination .nav-links { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.pagination .page-numbers {
	display: inline-block;
	padding: 0.45rem 0.8rem;
	border: 1px solid var(--cc-border);
	border-radius: var(--cc-radius);
	color: var(--cc-text-soft);
}
.pagination .page-numbers.current,
.pagination .page-numbers:hover { background: var(--cc-accent); color: #fff; border-color: var(--cc-accent); text-decoration: none; }

/* =============================================================================
   Footer
   ========================================================================== */
.site-footer {
	background: var(--cc-footer-bg);
	color: var(--cc-footer-text);
	margin-top: 2rem;
	padding-block: 2rem;
	font-size: 0.95rem;
}
.site-footer a { color: #fff; }
.site-footer a:hover { color: var(--cc-accent); }
.footer-widgets {
	display: grid;
	gap: 1.75rem;
	margin-bottom: 1.75rem;
}
@media (min-width: 40em) { .footer-widgets { grid-template-columns: repeat(3, 1fr); } }
.footer-widgets .widget-title { color: #fff; border-bottom-color: rgba(255,255,255,0.2); }
.footer-widgets li { border-bottom-color: rgba(255,255,255,0.1); }
.site-info { border-top: 1px solid rgba(255,255,255,0.15); padding-top: 1.25rem; color: var(--cc-footer-text); }

/* =============================================================================
   Accessibility helpers
   ========================================================================== */
.screen-reader-text {
	border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
	height: 1px; width: 1px; margin: -1px; padding: 0; overflow: hidden;
	position: absolute !important; word-wrap: normal !important;
}
.screen-reader-text:focus {
	background: #fff; clip: auto; clip-path: none;
	color: #1c1c1c; height: auto; width: auto; padding: 0.6rem 1rem;
	left: 0; top: 0; z-index: 1000;
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	* { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
