/**
 * RecipesJV — Base Styles
 * Body, typography, links, utility classes (.container, .btn, .section-title).
 * Builds on top of reset.css and variables.css.
 */

/* ─── Box Model & Body ──────────────────────────────────────────────── */

body {
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-text);
	background-color: var(--color-bg);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

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

/* ─── Links ─────────────────────────────────────────────────────────── */

a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition);
}

a:hover {
	color: var(--color-primary-dark);
}

/* ─── Headings ───────────────────────────────────────────────────────── */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	color: var(--color-text);
	line-height: 1.25;
	font-weight: 700;
	margin-block-start: 0;
	margin-block-end: var(--space-4);
}

h1 { font-size: var(--text-3xl); }
h2 { font-size: var(--text-2xl); }
h3 { font-size: var(--text-xl); }
h4 { font-size: var(--text-lg); }
h5 { font-size: var(--text-base); }
h6 { font-size: var(--text-sm); }

@media (min-width: 768px) {
	h1 { font-size: var(--text-4xl); }
	h2 { font-size: var(--text-3xl); }
}

/* ─── Paragraphs & Lists ─────────────────────────────────────────────── */

p {
	margin-block-start: 0;
	margin-block-end: var(--space-4);
}

ul, ol {
	padding-inline-start: var(--space-6);
	margin-block-end: var(--space-4);
}

/* ─── Forms ──────────────────────────────────────────────────────────── */

input,
textarea,
select {
	font-family: var(--font-body);
}

/* ─── Screen Reader Text ─────────────────────────────────────────────── */

.screen-reader-text {
	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(--color-bg);
	border-radius: var(--radius-sm);
	box-shadow: 0 0 0 3px var(--color-primary);
	clip: auto !important;
	clip-path: none;
	color: var(--color-text);
	display: block;
	font-size: var(--text-sm);
	font-weight: 700;
	height: auto;
	left: var(--space-4);
	line-height: normal;
	padding: var(--space-3) var(--space-6);
	top: var(--space-4);
	width: auto;
	z-index: 100000;
}

/* ─── Container ──────────────────────────────────────────────────────── */

.container {
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-padding);
}

/* ─── Buttons ────────────────────────────────────────────────────────── */

.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: var(--space-3) var(--space-6);
	border-radius: var(--radius-md);
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: var(--text-sm);
	text-decoration: none;
	transition: background-color var(--transition), color var(--transition), border-color var(--transition);
	cursor: pointer;
	border: 2px solid transparent;
	line-height: 1;
}

.btn--primary {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.btn--primary:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: var(--color-white);
}

.btn--outline {
	background-color: transparent;
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.btn--outline:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.btn--secondary {
	background-color: transparent;
	border-color: var(--color-border);
	color: var(--color-text);
}

.btn--secondary:hover {
	background-color: var(--color-bg-alt);
	border-color: var(--color-text-muted);
	color: var(--color-text);
}

/* ─── Section Title (shared across pages) ────────────────────────────── */

.section-title {
	font-size: var(--text-2xl);
	text-align: center;
	margin-bottom: var(--space-8);
	color: var(--color-text);
}

.section-title::after {
	content: '';
	display: block;
	width: 48px;
	height: 3px;
	background-color: var(--color-primary);
	margin: var(--space-3) auto 0;
	border-radius: 2px;
}

@media (min-width: 768px) {
	.section-title {
		font-size: var(--text-3xl);
	}
}

/* ─── Post / Entry Content Styles ────────────────────────────────────── */

.entry-content a {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}

.entry-content h2,
.entry-content h3,
.entry-content h4 {
	margin-block-start: var(--space-8);
}

.entry-content img {
	border-radius: var(--radius-md);
}

.entry-content ul,
.entry-content ol {
	margin-block-end: var(--space-6);
}

/* ─── WordPress Alignment Classes ────────────────────────────────────── */

.alignleft  { float: left;  margin-right: var(--space-6); margin-bottom: var(--space-4); }
.alignright { float: right; margin-left:  var(--space-6); margin-bottom: var(--space-4); }
.aligncenter { clear: both; display: block; margin-inline: auto; margin-bottom: var(--space-4); }
.alignwide  { margin-inline: calc(-1 * var(--space-8)); }
.alignfull  { margin-inline: calc(50% - 50vw); max-width: 100vw; width: 100vw; }

/* ─── Post Meta shared styles ────────────────────────────────────────── */

.post-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-2) var(--space-4);
	font-size: var(--text-sm);
	color: var(--color-text-muted);
}

.post-meta__category {
	font-family: var(--font-heading);
	font-size: var(--text-xs);
	font-weight: 700;
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.post-meta__category:hover {
	color: var(--color-primary-dark);
}

/* ─── Author Bio ─────────────────────────────────────────────────────── */

.author-bio {
	display: flex;
	gap: var(--space-6);
	align-items: flex-start;
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	margin-block: var(--space-12);
	border: 1px solid var(--color-border);
}

.author-bio__avatar {
	width: 80px !important; /* override WP default — needed for consistency */
	height: 80px !important;
	border-radius: 50%;
	flex-shrink: 0;
}

.author-bio__label {
	display: block;
	font-size: var(--text-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-primary);
	margin-bottom: var(--space-1);
}

.author-bio__name {
	font-size: var(--text-lg);
	margin-bottom: var(--space-2);
}

.author-bio__name a {
	color: var(--color-text);
}

.author-bio__name a:hover {
	color: var(--color-primary);
}

.author-bio__desc {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	line-height: 1.7;
	margin-bottom: 0;
}

@media (max-width: 480px) {
	.author-bio {
		flex-direction: column;
	}
}
