/*
Theme Name: Your Recipes
Theme URI: https://github.com/troywallwork/your.recipes
Author: Your Recipes
Description: A vintage recipe card theme with warm cream, kraft brown, and tomato red.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: your-recipes-theme
*/

/* =========================================================
   CSS Custom Properties — Vintage Recipe Card Palette
   ========================================================= */
:root {
	/* Cream parchment background */
	--color-bg:           #FDF6E3;
	/* Warm white card surface */
	--color-surface:      #FFFEF7;
	/* Warm tan border */
	--color-border:       #D4B896;
	/* Dark espresso text */
	--color-text:         #2C1810;
	/* Medium warm brown */
	--color-text-muted:   #8B6B52;
	/* Tomato red accent */
	--color-accent:       #C0392B;
	--color-accent-hover: #A93226;
	--color-accent-light: #FAEAEA;
	--color-accent-mid:   #F0D0CE;
	/* Kraft brown — navigation, borders, headings */
	--color-kraft:        #8B5E3C;
	--color-kraft-light:  #F5E6CC;
	--color-kraft-dark:   #5C3D24;
	--color-voted:        #2d7a3a;
	--color-voted-hover:  #246030;

	/* Playfair Display for headings, Lato for body */
	--font-serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
	--font-sans:  'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	--radius-sm:  3px;
	--radius-md:  6px;
	--radius-lg:  10px;
	--radius-xl:  14px;

	/* Warm brown-tinted shadows */
	--shadow-sm:  1px 2px 6px rgba(139, 94, 60, .12), 0 1px 2px rgba(139, 94, 60, .08);
	--shadow-md:  2px 4px 16px rgba(139, 94, 60, .14), 0 2px 4px rgba(139, 94, 60, .10);
	--shadow-lg:  4px 8px 28px rgba(139, 94, 60, .16), 0 4px 8px rgba(139, 94, 60, .10);

	--container:  1200px;
	--content:    800px;
	--gap:        1.5rem;
}

/* =========================================================
   Reset & Base
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: 1.7;
	color: var(--color-text);
	/* Cream parchment with a subtle ruled-line paper texture */
	background-color: var(--color-bg);
	background-image: repeating-linear-gradient(
		0deg,
		transparent,
		transparent 27px,
		rgba(139, 94, 60, .045) 27px,
		rgba(139, 94, 60, .045) 28px
	);
	-webkit-font-smoothing: antialiased;
}

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

a { color: var(--color-accent); text-decoration: none; }
a:hover { color: var(--color-accent-hover); }

ul, ol { padding-left: 0; list-style: none; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-serif);
	line-height: 1.25;
	color: var(--color-text);
}

/* =========================================================
   Layout Utilities
   ========================================================= */
.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: 1.5rem;
}

.content-container {
	width: 100%;
	max-width: var(--content);
	margin-inline: auto;
	padding-inline: 1.5rem;
}

/* Breadcrumb */
.breadcrumb {
	padding-block: 0.75rem;
	margin-bottom: 0.5rem;
}
.breadcrumb__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.25rem 0.4rem;
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0.8125rem;
	color: var(--color-text-muted);
}
.breadcrumb__item + .breadcrumb__item::before {
	content: '›';
	margin-right: 0.4rem;
	color: var(--color-border);
}
.breadcrumb__item a {
	color: var(--color-text-muted);
	text-decoration: none;
}
.breadcrumb__item a:hover {
	color: var(--color-accent);
	text-decoration: underline;
}
.breadcrumb__item[aria-current="page"] {
	color: var(--color-text);
	font-weight: 600;
}

/* =========================================================
   Site Header
   ========================================================= */
.site-header {
	background: var(--color-kraft-light);
	border-bottom: 2px solid var(--color-kraft);
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: 0 2px 8px rgba(139, 94, 60, .18);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 64px;
	gap: 1rem;
}

.site-branding {
	display: flex;
	align-items: center;
	gap: .625rem;
	text-decoration: none;
	flex-shrink: 0;
}

.site-branding__icon {
	font-size: 1.5rem;
	line-height: 1;
}

.site-branding__name {
	font-family: var(--font-serif);
	font-size: 1.35rem;
	font-weight: 700;
	font-style: italic;
	color: var(--color-kraft-dark);
	letter-spacing: .01em;
}

.site-branding__name span { color: var(--color-accent); }

/* =========================================================
   Site Navigation
   ========================================================= */
.site-nav {
	display: flex;
	align-items: center;
	gap: .25rem;
}

.site-nav a {
	display: inline-block;
	padding: .4rem .75rem;
	border-radius: var(--radius-sm);
	font-size: .875rem;
	font-weight: 700;
	color: var(--color-kraft-dark);
	text-decoration: none;
	letter-spacing: .01em;
	transition: color .15s, background .15s;
}

.site-nav a:hover,
.site-nav a[aria-current="page"] {
	color: var(--color-accent);
	background: rgba(192, 57, 43, .08);
}

/* --- Categories dropdown --- */
.site-nav__dropdown {
	position: relative;
}

.site-nav__dropdown-toggle {
	display: inline-flex;
	align-items: center;
	gap: .25rem;
	padding: .4rem .75rem;
	border: none;
	border-radius: var(--radius-sm);
	background: transparent;
	font-family: var(--font-sans);
	font-size: .875rem;
	font-weight: 700;
	color: var(--color-kraft-dark);
	letter-spacing: .01em;
	cursor: pointer;
	transition: color .15s, background .15s;
	white-space: nowrap;
}

.site-nav__dropdown-toggle:hover,
.site-nav__dropdown-toggle.is-active {
	color: var(--color-accent);
	background: rgba(192, 57, 43, .08);
}

.site-nav__dropdown-arrow {
	font-size: .7rem;
	transition: transform .15s;
}

.site-nav__dropdown-toggle[aria-expanded="true"] .site-nav__dropdown-arrow {
	transform: rotate(180deg);
}

.site-nav__dropdown-menu {
	display: none;
	position: absolute;
	top: calc(100% + .375rem);
	left: 0;
	min-width: 190px;
	background: var(--color-kraft-light);
	border: 1.5px solid var(--color-kraft);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-md);
	list-style: none;
	margin: 0;
	padding: .375rem 0;
	z-index: 200;
}

.site-nav__dropdown-menu.is-open {
	display: block;
}

.site-nav__dropdown-menu a {
	display: block;
	padding: .45rem 1rem;
	border-radius: 0;
	white-space: nowrap;
	color: var(--color-kraft-dark);
	font-weight: 700;
}

.site-nav__dropdown-menu a:hover,
.site-nav__dropdown-menu a[aria-current="page"] {
	color: var(--color-accent);
	background: rgba(192, 57, 43, .08);
}

/* =========================================================
   Site Footer
   ========================================================= */
.site-footer {
	background: #F5E6CC;
	background: var(--color-kraft-light, #F5E6CC);
	border-top: 2px solid #D4B896;
	border-top: 2px solid var(--color-kraft, #D4B896);
	margin-top: 4rem;
	padding: 2rem 0;
	min-height: 64px;
}

.site-footer__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.site-footer__nav {
	display: flex;
	align-items: center;
	gap: .25rem;
}

.site-footer__nav a {
	display: inline-block;
	padding: .4rem .75rem;
	border-radius: var(--radius-sm, 4px);
	font-size: .875rem;
	font-weight: 700;
	color: var(--color-kraft-dark, #5C3D24);
	text-decoration: none;
	letter-spacing: .01em;
	transition: color .15s, background .15s;
}

.site-footer__nav a:hover,
.site-footer__nav a[aria-current="page"] {
	color: var(--color-accent, #C0392B);
	background: rgba(192, 57, 43, .08);
}

.site-footer__copy {
	font-size: .875rem;
	color: var(--color-text-muted, #8B6B52);
}

.site-footer__copy a { color: var(--color-accent, #C0392B); }

/* =========================================================
   Page Wrapper
   ========================================================= */
.site-main { padding-top: 3rem; padding-bottom: 3rem; min-height: 60vh; }

/* =========================================================
   Page & Post Content
   ========================================================= */
.entry-header { margin-bottom: 2rem; }

.entry-title {
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	font-weight: 700;
	margin-bottom: .75rem;
}

.entry-content {
	font-size: 1.0625rem;
	line-height: 1.8;
}

.entry-content p + p { margin-top: 1.25em; }

.entry-content h2 { font-size: 1.5rem; margin-top: 2em; margin-bottom: .75em; }
.entry-content h3 { font-size: 1.25rem; margin-top: 1.75em; margin-bottom: .625em; }

.entry-content ul, .entry-content ol {
	padding-left: 1.5rem;
	margin-top: .75em;
	margin-bottom: .75em;
}
.entry-content ul { list-style: disc; }
.entry-content ol { list-style: decimal; }
.entry-content li + li { margin-top: .375em; }

/* =========================================================
   Archive / Recipe Card Grid
   ========================================================= */
.archive-header {
	padding-bottom: 2rem;
	border-bottom: 2px solid var(--color-kraft);
	margin-bottom: 2.5rem;
}

.archive-title {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-style: italic;
	color: var(--color-kraft-dark);
	margin-bottom: .375rem;
}

.archive-description { color: var(--color-text-muted); font-size: 1rem; }

.recipe-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--gap);
}

/* Recipe Card */
.recipe-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform .2s, box-shadow .2s;
	display: flex;
	flex-direction: column;
}

.recipe-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-lg);
}

.recipe-card__thumb {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--color-accent-mid);
}

.recipe-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .3s;
}

.recipe-card:hover .recipe-card__thumb img { transform: scale(1.04); }

.recipe-card__thumb-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 3rem;
	color: var(--color-accent);
	background: var(--color-accent-light);
}

.recipe-card__body {
	padding: 1.125rem 1.25rem 1.25rem;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.recipe-card__cats {
	display: flex;
	flex-wrap: wrap;
	gap: .375rem;
	margin-bottom: .625rem;
}

.recipe-card__cat {
	font-size: .65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--color-kraft);
	background: transparent;
	border: 1.5px solid var(--color-kraft);
	padding: .15rem .45rem;
	border-radius: 2px; /* stamp: square corners */
	transition: background .15s, color .15s;
}

.recipe-card__cat:hover {
	background: var(--color-kraft);
	color: var(--color-surface);
}

.recipe-card__title {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 700;
	font-style: italic;
	margin-bottom: auto;
	line-height: 1.35;
}

.recipe-card__title a { color: var(--color-text); }
.recipe-card__title a:hover { color: var(--color-accent); }

.recipe-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: .875rem;
	padding-top: .875rem;
	border-top: 1px solid var(--color-border);
}

.recipe-card__votes {
	display: flex;
	align-items: center;
	gap: .35rem;
	font-size: .875rem;
	color: var(--color-text-muted);
}

.recipe-card__votes-icon { font-size: 1rem; }

.recipe-card__link {
	font-size: .8rem;
	font-weight: 600;
	color: var(--color-accent);
	display: flex;
	align-items: center;
	gap: .2rem;
}

.recipe-card__link:hover { color: var(--color-accent-hover); }

.archive-empty {
	text-align: center;
	padding: 4rem 1rem;
	color: var(--color-text-muted);
}

.archive-empty__icon { font-size: 3rem; margin-bottom: 1rem; }
.archive-empty__title { font-size: 1.375rem; margin-bottom: .5rem; }

/* Archive pagination */
.archive-pagination {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: .5rem;
	margin-top: 3rem;
}

/* paginate_links() outputs .page-numbers on every link/span */
.archive-pagination a,
.archive-pagination span,
.archive-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 .75rem;
	border-radius: var(--radius-md);
	font-size: .9rem;
	font-weight: 500;
	border: 1px solid var(--color-border);
	background: var(--color-surface);
	color: var(--color-text);
	text-decoration: none;
	flex-shrink: 0;
}

.archive-pagination a:hover,
.archive-pagination a.page-numbers:hover { background: #8B4513; border-color: #8B4513; color: #fff; }
.archive-pagination .current { background: #8B4513; color: #fff; border-color: #8B4513; }

/* =========================================================
   Single Recipe
   ========================================================= */
.recipe-hero {
	aspect-ratio: 16 / 7;
	overflow: hidden;
	background: var(--color-accent-mid);
	border-radius: var(--radius-xl);
	margin-bottom: 2.5rem;
}

.recipe-hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.recipe-header { margin-bottom: 2rem; }

.recipe-title {
	font-size: clamp(1.875rem, 4vw, 3rem);
	font-weight: 700;
	margin-bottom: 1rem;
	line-height: 1.2;
}

.recipe-categories {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	margin-bottom: 1rem;
}

.recipe-category-tag {
	font-size: .65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--color-kraft);
	background: transparent;
	border: 1.5px solid var(--color-kraft);
	padding: .25rem .65rem;
	border-radius: 2px; /* stamp style */
	transition: background .15s, color .15s;
}

.recipe-category-tag:hover {
	background: var(--color-kraft);
	color: var(--color-surface);
}

/* Meta bar (times + yield) */
.recipe-meta-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 1px;
	background: var(--color-border);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	margin-bottom: 2.5rem;
}

.recipe-meta-item {
	flex: 1;
	min-width: 120px;
	background: var(--color-kraft-light);
	padding: 1rem 1.25rem;
	text-align: center;
}

.recipe-meta-item__label {
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--color-kraft);
	margin-bottom: .25rem;
}

.recipe-meta-item__value {
	font-family: var(--font-serif);
	font-size: 1.0625rem;
	font-weight: 700;
	color: var(--color-text);
}


/* Recipe sections */
.recipe-section { margin-bottom: 2.5rem; }

.recipe-section__title {
	font-family: var(--font-serif);
	font-size: 1.375rem;
	font-weight: 700;
	font-style: italic;
	color: var(--color-kraft-dark);
	padding-bottom: .625rem;
	border-bottom: 2px solid var(--color-kraft);
	margin-bottom: 1.25rem;
	display: flex;
	align-items: center;
	gap: .5rem;
}

/* Ingredients */
.ingredients-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: .5rem;
}

.ingredient-item {
	display: flex;
	align-items: baseline;
	gap: .625rem;
	padding: .625rem .75rem;
	background: var(--color-bg);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
	font-size: .9375rem;
	line-height: 1.4;
}

.ingredient-item::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	min-width: 6px;
	border-radius: 50%;
	background: var(--color-accent);
	margin-top: .45rem;
}

/* Steps */
.steps-list { counter-reset: steps; display: flex; flex-direction: column; gap: 1.25rem; }

.step-item {
	display: flex;
	gap: 1.125rem;
	padding: 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	line-height: 1.7;
}

.step-item__number {
	flex-shrink: 0;
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	background: var(--color-accent);
	color: #fff;
	font-weight: 700;
	font-size: .875rem;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: .125rem;
}

.step-item__text { font-size: 1rem; color: var(--color-text); }

/* Nutrition */
.nutrition-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: .75rem;
}

.nutrition-item {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: .75rem 1rem;
	text-align: center;
}

.nutrition-item__label {
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--color-text-muted);
	margin-bottom: .2rem;
}

.nutrition-item__value {
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--color-text);
}

/* Vote / favourite */
.recipe-vote {
	display: flex;
	align-items: center;
	gap: .875rem;
	margin-bottom: 2.5rem;
}

.btn-heart {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .55rem 1.125rem;
	border: 2px solid var(--color-border);
	border-radius: 2rem;
	background: var(--color-surface);
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-text-muted);
	cursor: pointer;
	user-select: none;
	transition: border-color .15s, color .15s, background .15s, transform .1s;
}

.btn-heart:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
	background: var(--color-accent-light);
}

.btn-heart:active { transform: scale(.94); }

.btn-heart:disabled {
	opacity: .6;
	cursor: not-allowed;
	transform: none;
}

.btn-heart--active {
	border-color: var(--color-accent);
	color: var(--color-accent);
	background: var(--color-accent-light);
}

.btn-heart__icon { font-size: 1.2rem; line-height: 1; }
.btn-heart__count { font-size: .9375rem; }

/* Compact variant used inside recipe cards */
.btn-heart--card {
	padding: .2rem .45rem;
	font-size: .8125rem;
	font-weight: 400;
	border-width: 1px;
	gap: .2rem;
	border-radius: var(--radius-md);
}

.vote-hint {
	font-size: .875rem;
	color: var(--color-text-muted);
	font-style: italic;
}

/* Origin */
.recipe-origin {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .75rem 1.125rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: .875rem;
	color: var(--color-text-muted);
}

.recipe-origin a {
	color: var(--color-accent);
	font-weight: 500;
	word-break: break-all;
}

.recipe-origin a:hover { color: var(--color-accent-hover); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 900px) {
	.recipe-grid { grid-template-columns: repeat(2, 1fr); }
	.ingredients-list { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
	.recipe-grid { grid-template-columns: 1fr; }
	.recipe-meta-bar { flex-direction: column; }
	.recipe-meta-item { min-width: 0; }
	.recipe-hero { aspect-ratio: 4 / 3; border-radius: var(--radius-lg); }
	.recipe-vote { flex-direction: column; align-items: flex-start; }
	.site-header__inner { height: 56px; }
	.site-nav { gap: 0; }
	.site-nav a,
	.site-nav__dropdown-toggle { padding: .35rem .5rem; font-size: .8rem; }
	.site-nav__dropdown-menu { min-width: 150px; }
}

/* =========================================================
   Add Recipe Page
   ========================================================= */

.add-recipe-login {
	max-width: 480px;
	margin: 3rem auto;
	padding: 2.5rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-sm);
	text-align: center;
}

.add-recipe-login__icon { font-size: 2.5rem; margin-bottom: 1rem; }
.add-recipe-login__title { font-size: 1.375rem; margin-bottom: .625rem; }
.add-recipe-login__text { color: var(--color-text-muted); margin-bottom: 1.5rem; }

.btn-primary {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .7rem 1.5rem;
	background: #8B4513;
	color: #fff;
	border: none;
	border-radius: var(--radius-md);
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	transition: background .15s, transform .1s;
}

.btn-primary:hover { background: #6B3010; color: #fff; }
.btn-primary:active { transform: scale(.97); }
.btn-primary:disabled {
	background: var(--color-border);
	color: var(--color-text-muted);
	cursor: not-allowed;
	transform: none;
}

.btn-secondary {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .7rem 1.5rem;
	background: transparent;
	color: var(--color-text-muted);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: border-color .15s, color .15s;
}

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

.add-recipe-form-wrap {
	max-width: 640px;
	margin: 0 auto 2.5rem;
}

.add-recipe-form-wrap h1 {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	margin-bottom: .5rem;
}

.add-recipe-form-wrap .page-intro {
	color: var(--color-text-muted);
	margin-bottom: 2rem;
}

.url-form {
	display: flex;
	gap: .75rem;
	align-items: stretch;
}

.url-form__input {
	flex: 1;
	padding: .75rem 1rem;
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	font-family: var(--font-sans);
	font-size: 1rem;
	color: var(--color-text);
	background: var(--color-surface);
	transition: border-color .15s;
	min-width: 0;
}

.url-form__input:focus {
	outline: none;
	border-color: var(--color-accent);
}

.url-form__input::placeholder { color: var(--color-text-muted); }

.url-form__hint {
	margin-top: .625rem;
	font-size: .8125rem;
	color: var(--color-text-muted);
}

.url-form__manual-link {
	margin-top: .5rem;
	font-size: .8125rem;
	color: var(--color-text-muted);
}

.url-form__manual-link a {
	color: var(--color-accent);
	font-weight: 500;
}

.url-form__manual-link a:hover { color: var(--color-accent-hover); }

/* Error banner */
.add-recipe-error {
	display: none;
	align-items: flex-start;
	gap: .75rem;
	padding: 1rem 1.25rem;
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: var(--radius-md);
	margin-top: 1rem;
	color: #b91c1c;
	font-size: .9375rem;
}

.add-recipe-error.is-visible { display: flex; }
.add-recipe-error__icon { flex-shrink: 0; font-size: 1.125rem; }

/* Spinner */
.add-recipe-spinner {
	display: none;
	justify-content: center;
	align-items: center;
	gap: .75rem;
	padding: 3rem;
	color: var(--color-text-muted);
}

.add-recipe-spinner.is-visible { display: flex; }

.spinner-ring {
	width: 2rem;
	height: 2rem;
	border: 3px solid var(--color-border);
	border-top-color: var(--color-accent);
	border-radius: 50%;
	animation: spin .7s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* Preview panel */
.recipe-preview {
	display: none;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-xl);
	background: var(--color-surface);
	overflow: hidden;
	box-shadow: var(--shadow-md);
}

.recipe-preview.is-visible { display: block; }

.recipe-preview__image {
	aspect-ratio: 16 / 7;
	overflow: hidden;
	background: var(--color-accent-mid);
}

.recipe-preview__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.recipe-preview__body { padding: 1.75rem 2rem 2rem; }

.recipe-preview__origin {
	font-size: .8125rem;
	color: var(--color-text-muted);
	margin-bottom: .625rem;
	word-break: break-all;
}

.recipe-preview__title {
	font-size: clamp(1.375rem, 3vw, 2rem);
	margin-bottom: 1.5rem;
	line-height: 1.25;
}

.recipe-preview__section-title {
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .07em;
	color: var(--color-text-muted);
	margin-bottom: .75rem;
}

.recipe-preview__ingredients {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: .375rem;
	margin-bottom: 1.5rem;
}

.recipe-preview__ingredient {
	display: flex;
	align-items: baseline;
	gap: .5rem;
	font-size: .9375rem;
	padding: .5rem .625rem;
	background: var(--color-bg);
	border-radius: var(--radius-sm);
}

.recipe-preview__ingredient::before {
	content: '';
	display: inline-block;
	width: 5px;
	height: 5px;
	min-width: 5px;
	border-radius: 50%;
	background: var(--color-accent);
	margin-top: .4rem;
}

.recipe-preview__steps { display: flex; flex-direction: column; gap: .875rem; margin-bottom: 1.75rem; }

.recipe-preview__step {
	display: flex;
	gap: .875rem;
	font-size: .9375rem;
	line-height: 1.6;
}

.recipe-preview__step-num {
	flex-shrink: 0;
	width: 1.625rem;
	height: 1.625rem;
	border-radius: 50%;
	background: var(--color-accent);
	color: #fff;
	font-size: .75rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: .175rem;
}

.recipe-preview__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1px;
	background: var(--color-border);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	margin-bottom: 1.5rem;
}

.recipe-preview__meta-item {
	flex: 1;
	min-width: 90px;
	background: var(--color-bg);
	padding: .625rem .875rem;
	text-align: center;
}

.recipe-preview__meta-label {
	font-size: .65rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .09em;
	color: var(--color-text-muted);
	margin-bottom: .2rem;
}

.recipe-preview__meta-value {
	font-family: var(--font-serif);
	font-size: .9375rem;
	font-weight: 700;
	color: var(--color-text);
}

.recipe-preview__actions {
	display: flex;
	gap: .75rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--color-border);
	flex-wrap: wrap;
}

@media (max-width: 600px) {
	.url-form { flex-direction: column; }
	.recipe-preview__ingredients { grid-template-columns: 1fr; }
	.recipe-preview__body { padding: 1.25rem; }
}

/* =========================================================
   Recipe Author Credit
   ========================================================= */

.recipe-author {
	font-size: .9rem;
	color: var(--color-text-muted);
	margin-top: .375rem;
}

.recipe-author a { color: var(--color-accent); font-weight: 500; }
.recipe-author a:hover { color: var(--color-accent-hover); }

/* =========================================================
   Category Filter Bar
   ========================================================= */

.category-filter {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	margin-bottom: 2rem;
}

.category-filter__link {
	display: inline-block;
	padding: .35rem .875rem;
	border: 1.5px solid var(--color-kraft);
	border-radius: 2px; /* stamp style */
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--color-kraft);
	background: transparent;
	transition: border-color .15s, color .15s, background .15s;
	white-space: nowrap;
}

.category-filter__link:hover {
	background: var(--color-kraft);
	color: var(--color-surface);
}

.category-filter__link--active {
	background: var(--color-kraft);
	border-color: var(--color-kraft);
	color: var(--color-surface);
}

.category-filter__link--active:hover {
	background: var(--color-kraft-dark);
	border-color: var(--color-kraft-dark);
	color: var(--color-surface);
}

/* =========================================================
   My Account Page
   ========================================================= */

.my-account-um { margin-bottom: 3rem; }

.my-account-header {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	padding: 1.5rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	margin-bottom: 2.5rem;
}

.my-account-avatar img {
	border-radius: 50%;
	width: 80px;
	height: 80px;
	object-fit: cover;
}

.my-account-name {
	font-size: 1.375rem;
	margin-bottom: .2rem;
}

/* =========================================================
   Account Tabs (Favorites / My Recipes)
   ========================================================= */
.account-tabs {
	display: flex;
	gap: .5rem;
	border-bottom: 2px solid var(--color-kraft);
	margin-bottom: 2rem;
}

.account-tab {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .625rem 1.25rem;
	font-family: var(--font-sans);
	font-size: .9375rem;
	font-weight: 700;
	color: var(--color-kraft);
	text-decoration: none;
	border: 1.5px solid transparent;
	border-bottom: none;
	border-radius: var(--radius-sm) var(--radius-sm) 0 0;
	background: transparent;
	transition: background .15s, color .15s;
	position: relative;
	bottom: -2px;
}

.account-tab:hover {
	background: var(--color-kraft-light);
	color: var(--color-kraft-dark);
}

.account-tab--active {
	background: var(--color-kraft-light);
	border-color: var(--color-kraft);
	border-bottom-color: var(--color-kraft-light);
	color: var(--color-kraft-dark);
}

.account-tab--active:hover {
	color: var(--color-kraft-dark);
}

.account-tab-panel {
	padding-top: .5rem;
}

.my-account-email {
	font-size: .875rem;
	color: var(--color-text-muted);
}

.my-account-signout {
	display: inline-block;
	margin-top: .25rem;
	font-size: 13px;
	color: var(--color-text-muted);
	text-decoration: none;
}

.my-account-signout:hover {
	text-decoration: underline;
}

/* =========================================================
   Header Search
   ========================================================= */
.header-search {
	display: flex;
	align-items: center;
	gap: 0;
	flex: 1;
	max-width: 320px;
	margin: 0 1rem;
}

.header-search__input {
	flex: 1;
	min-width: 0;
	height: 2.25rem;
	padding: 0 .75rem;
	border: 1.5px solid var(--color-border);
	border-right: none;
	border-radius: var(--radius-md) 0 0 var(--radius-md);
	font-family: var(--font-sans);
	font-size: .875rem;
	color: var(--color-text);
	background: var(--color-surface);
	transition: border-color .15s;
}

.header-search__input:focus {
	outline: none;
	border-color: var(--color-accent);
}

.header-search__input::placeholder { color: var(--color-text-muted); }

.header-search__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 2.25rem;
	width: 2.5rem;
	border: 1.5px solid var(--color-border);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	background: var(--color-surface);
	color: var(--color-text-muted);
	cursor: pointer;
	transition: background .15s, color .15s, border-color .15s;
	flex-shrink: 0;
}

.header-search__btn:hover {
	background: var(--color-accent);
	border-color: var(--color-accent);
	color: #fff;
}

@media (max-width: 600px) {
	.header-search { max-width: none; margin: 0 .5rem; }
	.header-search__input { font-size: .8rem; }
}

/* =========================================================
   Social Sharing
   ========================================================= */
.recipe-share {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .625rem;
	margin-bottom: 2rem;
}

.recipe-share__label {
	font-size: .8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--color-text-muted);
	margin-right: .25rem;
}

.recipe-share__btn {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .45rem .875rem;
	border-radius: var(--radius-md);
	font-size: .8125rem;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	border: 1.5px solid transparent;
	transition: opacity .15s, transform .1s;
}

.recipe-share__btn:active { transform: scale(.96); }

.recipe-share__btn--facebook {
	background: #1877f2;
	color: #fff;
	border-color: #1877f2;
}

.recipe-share__btn--facebook:hover { opacity: .88; color: #fff; }

.recipe-share__btn--pinterest {
	background: #e60023;
	color: #fff;
	border-color: #e60023;
}

.recipe-share__btn--pinterest:hover { opacity: .88; color: #fff; }

.recipe-share__btn--whatsapp {
	background: #25D366;
	color: #fff;
	border-color: #25D366;
}

.recipe-share__btn--whatsapp:hover { opacity: .88; color: #fff; }

.recipe-share__btn--reddit {
	background: #FF4500;
	color: #fff;
	border-color: #FF4500;
}

.recipe-share__btn--reddit:hover { opacity: .88; color: #fff; }

.recipe-share__btn--email {
	background: var(--color-surface);
	color: var(--color-text-muted);
	border-color: var(--color-border);
	font-family: var(--font-sans);
}

.recipe-share__btn--email:hover { border-color: var(--color-accent); color: var(--color-accent); }

.recipe-share__btn--copy {
	background: var(--color-surface);
	color: var(--color-text-muted);
	border-color: var(--color-border);
	font-family: var(--font-sans);
}

.recipe-share__btn--copy:hover { border-color: var(--color-accent); color: var(--color-accent); }
.recipe-share__btn--copy.is-copied { background: var(--color-accent-light); border-color: var(--color-accent); color: var(--color-accent); }

/* =========================================================
   Related Recipes
   ========================================================= */
.related-recipes {
	margin-top: 3.5rem;
	padding-top: 2.5rem;
	border-top: 1px solid var(--color-border);
}

.related-recipes__heading {
	font-family: var(--font-serif);
	font-size: 1.375rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
}

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

@media (max-width: 700px) {
	.related-recipes__grid { grid-template-columns: 1fr; }
}

/* =========================================================
   Manual Recipe Form
   ========================================================= */
.manual-form-wrap {
	max-width: 680px;
	margin: 0 auto 3rem;
}

.manual-form-wrap h1 {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	margin-bottom: .5rem;
}

.manual-form-wrap .page-intro {
	color: var(--color-text-muted);
	margin-bottom: 2rem;
}

.manual-form { display: flex; flex-direction: column; gap: 1.75rem; }

.manual-form__field { display: flex; flex-direction: column; gap: .5rem; }

.manual-form__label {
	font-size: .9375rem;
	font-weight: 600;
	color: var(--color-text);
}

.manual-form__optional {
	font-size: .8125rem;
	font-weight: 400;
	color: var(--color-text-muted);
	margin-left: .25rem;
}

.manual-form__input {
	padding: .65rem .875rem;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-md);
	font-family: var(--font-sans);
	font-size: .9375rem;
	color: var(--color-text);
	background: var(--color-surface);
	transition: border-color .15s;
	width: 100%;
	box-sizing: border-box;
}

.manual-form__input:focus { outline: none; border-color: var(--color-accent); }
.manual-form__select { cursor: pointer; }
.manual-form__textarea { resize: vertical; min-height: 3rem; }

.manual-form__hint {
	font-size: .8125rem;
	color: var(--color-text-muted);
	margin-top: .2rem;
}

.manual-form__rows { display: flex; flex-direction: column; gap: .5rem; }

.manual-form__row {
	display: flex;
	align-items: flex-start;
	gap: .5rem;
}

.manual-form__row .manual-form__input { flex: 1; }

.manual-form__row--step { align-items: flex-start; }

.manual-form__step-num {
	flex-shrink: 0;
	width: 1.75rem;
	height: 1.75rem;
	margin-top: .55rem;
	border-radius: 50%;
	background: var(--color-accent);
	color: #fff;
	font-size: .75rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
}

.manual-form__row-remove {
	flex-shrink: 0;
	width: 2rem;
	height: 2rem;
	margin-top: .45rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	background: transparent;
	color: var(--color-text-muted);
	font-size: .875rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: border-color .15s, color .15s;
}

.manual-form__row-remove:hover { border-color: #ef4444; color: #ef4444; }

.manual-form__add-row {
	align-self: flex-start;
	margin-top: .25rem;
	padding: .4rem .875rem;
	border: 1.5px dashed var(--color-border);
	border-radius: var(--radius-md);
	background: transparent;
	font-family: var(--font-sans);
	font-size: .875rem;
	font-weight: 600;
	color: var(--color-text-muted);
	cursor: pointer;
	transition: border-color .15s, color .15s;
}

.manual-form__add-row:hover { border-color: var(--color-accent); color: var(--color-accent); }

.manual-form__file {
	padding: .5rem 0;
	font-size: .9375rem;
	color: var(--color-text);
}

.manual-form__image-preview {
	margin-top: .625rem;
	max-width: 280px;
	border-radius: var(--radius-md);
	overflow: hidden;
	border: 1px solid var(--color-border);
}

.manual-form__image-preview img {
	width: 100%;
	height: auto;
	display: block;
}

.manual-form__actions {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding-top: .5rem;
}

.my-recipes-section { margin-top: 2.5rem; }

.my-recipes-heading {
	font-size: 1.375rem;
	margin-bottom: 1.5rem;
	padding-bottom: .625rem;
	border-bottom: 2px solid var(--color-accent);
}

/* =========================================================
   Supported Sites Page
   ========================================================= */
.supported-sites__cta {
	margin-top: 1.25rem;
	display: inline-flex;
}

.supported-sites-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1rem;
	margin: 2.5rem 0;
}

.supported-site-card {
	display: flex;
	align-items: flex-start;
	gap: .875rem;
	padding: 1.125rem 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	text-decoration: none;
	color: inherit;
	transition: border-color .15s, box-shadow .15s, transform .1s;
}

.supported-site-card:hover {
	border-color: var(--color-accent);
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.supported-site-card__icon {
	flex-shrink: 0;
	width: 2rem;
	height: 2rem;
	border-radius: var(--radius-sm);
	overflow: hidden;
	background: var(--color-bg);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: .1rem;
}

.supported-site-card__icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.supported-site-card__body {
	flex: 1;
	min-width: 0;
}

.supported-site-card__name {
	font-size: .9375rem;
	font-weight: 700;
	color: var(--color-text);
	margin-bottom: .25rem;
	line-height: 1.3;
}

.supported-site-card__desc {
	font-size: .8125rem;
	color: var(--color-text-muted);
	line-height: 1.5;
	margin-bottom: .375rem;
}

.supported-site-card__domain {
	font-size: .75rem;
	color: var(--color-accent);
	font-weight: 500;
}

.supported-site-card__arrow {
	flex-shrink: 0;
	font-size: 1rem;
	color: var(--color-text-muted);
	transition: color .15s, transform .15s;
	margin-top: .1rem;
}

.supported-site-card:hover .supported-site-card__arrow {
	color: var(--color-accent);
	transform: translateX(3px);
}

.supported-sites-footer {
	text-align: center;
	padding: 2rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-xl);
	margin-bottom: 3rem;
}

.supported-sites-footer p {
	color: var(--color-text-muted);
	margin-bottom: 1.25rem;
}

/* =========================================================
   Print Recipe Button
   ========================================================= */
.recipe-header-actions {
	margin-top: .875rem;
}

.btn-print {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .4rem .875rem;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-surface);
	font-family: var(--font-sans);
	font-size: .8125rem;
	font-weight: 600;
	color: var(--color-text-muted);
	cursor: pointer;
	transition: border-color .15s, color .15s;
}

.btn-print:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
}

/* =========================================================
   Homepage explainer section
   ========================================================= */
.site-explainer {
	text-align: center;
	padding: 2.5rem 0 2rem;
	margin-bottom: 2rem;
	border-bottom: 1px solid var(--color-border);
}
.site-explainer__headline {
	font-family: var(--font-serif);
	font-size: clamp(1.5rem, 4vw, 2rem);
	color: var(--color-kraft-dark);
	margin: 0 0 0.5rem;
}
.site-explainer__sub {
	color: var(--color-text-muted);
	font-size: 1rem;
	max-width: 520px;
	margin: 0 auto 2rem;
}
.site-explainer__steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	max-width: 700px;
	margin: 0 auto 2rem;
}
@media (max-width: 600px) {
	.site-explainer__steps { grid-template-columns: 1fr; gap: 1rem; }
}
.site-explainer__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
}
.site-explainer__icon {
	font-size: 1.75rem;
	line-height: 1;
}
.site-explainer__step-label {
	font-family: var(--font-serif);
	font-size: 1rem;
	color: var(--color-kraft-dark);
}
.site-explainer__step-desc {
	font-size: 0.875rem;
	color: var(--color-text-muted);
	margin: 0;
}
.site-explainer__cta {
	margin: 0;
}

/* =========================================================
   Add Recipe page explainer
   ========================================================= */
.add-recipe-explainer {
	margin: 1.5rem 0 2rem;
}
.add-recipe-explainer__steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	max-width: 700px;
	margin: 0 auto;
	text-align: center;
}
@media (max-width: 600px) {
	.add-recipe-explainer__steps { grid-template-columns: 1fr; gap: 1rem; }
}
.add-recipe-explainer__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
}
.add-recipe-explainer__icon {
	font-size: 1.75rem;
	line-height: 1;
}
.add-recipe-explainer__step-label {
	font-family: var(--font-serif);
	font-size: 1rem;
	color: var(--color-kraft-dark, #5C3D24);
}
.add-recipe-explainer__step-desc {
	font-size: 0.875rem;
	color: var(--color-text-muted, #8B6B52);
	margin: 0;
}

/* =========================================================
   Welcome / onboarding notice
   ========================================================= */
.welcome-notice {
	position: fixed;
	bottom: 1.25rem;
	left: 50%;
	transform: translateX(-50%);
	width: min(92vw, 560px);
	background: var(--color-kraft-light);
	border: 1.5px solid var(--color-kraft);
	border-radius: var(--radius);
	padding: 1rem 3rem 1rem 1.25rem;
	box-shadow: 0 4px 16px rgba(92,61,36,.15);
	display: flex;
	align-items: center;
	gap: 1rem;
	z-index: 9999;
}
.welcome-notice__text {
	margin: 0;
	font-size: 0.9rem;
	color: var(--color-text);
	line-height: 1.5;
}
.welcome-notice__dismiss {
	position: absolute;
	top: 0.5rem;
	right: 0.75rem;
	background: none;
	border: none;
	font-size: 1rem;
	line-height: 1;
	color: var(--color-text-muted);
	cursor: pointer;
	padding: 0.25rem;
}
.welcome-notice__dismiss:hover { color: var(--color-text); }

/* =========================================================
   About page
   ========================================================= */
.page-about {
	max-width: 640px;
	margin: 3rem auto;
}
.page-about__title {
	font-family: var(--font-serif);
	font-size: clamp(1.6rem, 4vw, 2.25rem);
	color: var(--color-kraft-dark);
	margin: 0 0 1.5rem;
}
.page-about__body p {
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--color-text);
	margin: 0 0 1.25rem;
}
.page-about__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 2rem;
}

/* =========================================================
   Ad slots
   ========================================================= */
.ad-slot {
	text-align: center;
	margin: 1.5rem 0;
	min-height: 90px;
}

/* =========================================================
   Comments
   ========================================================= */
.comments-area {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--color-border, #D4B896);
}

.comments-area__title {
	font-family: var(--font-serif, Georgia, serif);
	font-size: 1.25rem;
	color: var(--color-kraft-dark, #5C3D24);
	margin: 0 0 1.5rem;
}

/* Comment list */
.comment-list {
	list-style: none;
	margin: 0 0 2rem;
	padding: 0;
}

.comment-list .comment {
	padding: 1.25rem 0;
	border-bottom: 1px solid var(--color-border, #D4B896);
}

.comment-list .comment:last-child {
	border-bottom: none;
}

.comment-list .comment-meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.5rem;
}

.comment-list .comment-author .fn {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--color-text, #2C1810);
}

.comment-list .comment-author img {
	border-radius: 50%;
	flex-shrink: 0;
}

.comment-list .comment-metadata a {
	font-size: 0.8rem;
	color: var(--color-text-muted, #8B6D5C);
	text-decoration: none;
}

.comment-list .comment-metadata a:hover {
	text-decoration: underline;
}

.comment-list .comment-body p {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--color-text, #2C1810);
}

.comment-list .reply {
	margin-top: 0.5rem;
}

.comment-list .reply a {
	font-size: 0.8rem;
	color: var(--color-primary, #8B4513);
	text-decoration: none;
}

.comment-list .reply a:hover {
	text-decoration: underline;
}

/* Children (threaded replies) */
.comment-list .children {
	list-style: none;
	margin: 0.5rem 0 0 2rem;
	padding: 0;
}

/* Comment form */
.comment-form {
	margin-top: 1.5rem;
}

.comment-form p {
	margin: 0 0 1rem;
}

.comment-form textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 6px;
	font-family: inherit;
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--color-text, #2C1810);
	background: #fff;
	resize: vertical;
	box-sizing: border-box;
}

.comment-form textarea:focus {
	outline: none;
	border-color: var(--color-primary, #8B4513);
	box-shadow: 0 0 0 2px rgba(139, 69, 19, 0.15);
}

.comment-form .form-submit {
	margin: 0;
}

.comment-form .form-submit .submit {
	display: inline-block;
	padding: 0.65rem 1.5rem;
	background: var(--color-primary, #8B4513);
	color: #fff;
	border: none;
	border-radius: 6px;
	font-family: inherit;
	font-size: 0.9rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s;
}

.comment-form .form-submit .submit:hover {
	background: var(--color-kraft-dark, #5C3D24);
}

/* Login prompt for logged-out users */
.comment-login-prompt {
	margin-top: 1.5rem;
	padding: 1.25rem 1.5rem;
	background: var(--color-surface, #FFF8F0);
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 8px;
	font-size: 0.95rem;
	color: var(--color-text-muted, #8B6D5C);
}

.comment-login-prompt a {
	color: var(--color-primary, #8B4513);
	font-weight: 600;
}

/* =========================================================
   @media print fallback (primary styles in assets/print.css)
   ========================================================= */
@media print {
	.site-header,
	.site-footer,
	.header-search,
	.site-nav,
	.recipe-vote,
	.recipe-share,
	.recipe-origin,
	.recipe-header-actions,
	.related-recipes,
	.archive-pagination,
	.btn-print {
		display: none !important;
	}

	body { font-size: 11pt; color: #000; background: #fff; }

	.container,
	.content-container { max-width: 100%; padding: 0; margin: 0; }

	.recipe-hero { max-height: 220px; aspect-ratio: unset; }

	.recipe-title { font-size: 22pt; }

	.recipe-section { page-break-inside: avoid; }

	a { color: #000; text-decoration: none; }
	a[href]::after { content: none; }
}

/* =========================================================
   Ultimate Member overrides
   ========================================================= */

/* Buttons — all UM form buttons (primary, secondary, submit) */
.um .um-button,
.um input[type="submit"],
.um button[type="submit"] {
	background-color: #fffef7 !important;
	background-image: none !important;
	border: 1px solid rgb(212, 184, 150) !important;
	color: rgb(44, 24, 16) !important;
	font-family: Lato, sans-serif !important;
	font-size: 14px !important;
	font-weight: normal !important;
	text-shadow: none !important;
	box-shadow: none !important;
	border-radius: 4px !important;
}

.um .um-button:hover,
.um input[type="submit"]:hover,
.um button[type="submit"]:hover {
	background-color: rgb(212, 184, 150) !important;
	color: rgb(44, 24, 16) !important;
}

/* Inline links inside UM forms */
.um a.um-link {
	color: var(--color-primary, #8B4513) !important;
}

.um a.um-link:hover,
.um a.um-link-hvr:hover {
	color: var(--color-kraft-dark, #5C3D24) !important;
}

/* Subtitle shown above the register / login form */
.um-page-subtitle {
	text-align: center;
	color: var(--color-text-muted, #8B6D5C);
	font-size: 0.95rem;
	margin: 0 0 1.25rem;
	line-height: 1.5;
}

/* =========================================================
   Sort control (homepage + archive)
   ========================================================= */

.sort-control {
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: 1.25rem;
}

.sort-control__label {
	font-size: .875rem;
	color: var(--color-text-muted, #8B6D5C);
	font-weight: 600;
}

.sort-control__btn {
	display: inline-block;
	padding: .3rem .75rem;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 999px;
	font-size: .875rem;
	color: var(--color-text, #3E2010);
	text-decoration: none;
	line-height: 1.5;
	transition: background .15s, color .15s, border-color .15s;
}

.sort-control__btn:hover {
	background: var(--color-surface, #FFF8F0);
	border-color: var(--color-primary, #8B4513);
	color: var(--color-primary, #8B4513);
}

.sort-control__btn--active {
	background: #8B4513;
	border-color: #8B4513;
	color: #fff;
	font-weight: 600;
}

.sort-control__btn--active:hover {
	background: #6B3010;
	border-color: #6B3010;
	color: #fff;
}

/* =========================================================
   Letter avatar
   ========================================================= */

img.yr-letter-avatar {
	border-radius: 50%;
	display: block;
	flex-shrink: 0;
}

/* =========================================================
   Collections — Save to collection button
   ========================================================= */

.btn-collection {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .35rem .75rem;
	background: var(--color-surface, #FFF8F0);
	border: 1px solid var(--color-border, #D4B896);
	border-radius: var(--radius-md, 6px);
	color: var(--color-text-muted, #8B6D5C);
	font-family: Lato, sans-serif;
	font-size: .875rem;
	font-weight: 400;
	cursor: pointer;
	line-height: 1.4;
	transition: background .15s, border-color .15s, color .15s;
	white-space: nowrap;
}

.btn-collection:hover {
	background: var(--color-kraft, #D4B896);
	border-color: var(--color-kraft-dark, #5C3D24);
	color: var(--color-text, #3E2010);
}

/* Compact card variant — matches btn-heart--card sizing */
.btn-collection--card {
	padding: .2rem .4rem;
	font-size: .8125rem;
	border-width: 1px;
	gap: .15rem;
	border-radius: var(--radius-md, 6px);
}

/* =========================================================
   Collections — Dropdown
   ========================================================= */

.collection-dropdown {
	position: absolute;
	z-index: 200;
	min-width: 220px;
	max-width: 280px;
	margin-top: .25rem;
}

/* Single recipe page dropdown sits below the btn-collection inline */
.collection-dropdown--single {
	position: static;
	margin-top: .5rem;
	max-width: 300px;
}

.collection-dropdown__inner {
	background: #fff;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 8px;
	box-shadow: 0 4px 16px rgba(62, 32, 16, .12);
	overflow: hidden;
}

.collection-dropdown__loading,
.collection-dropdown__msg {
	padding: .75rem 1rem;
	font-size: .875rem;
	color: var(--color-text-muted, #8B6D5C);
}

.collection-dropdown__list {
	list-style: none;
	margin: 0;
	padding: .25rem 0;
	max-height: 200px;
	overflow-y: auto;
}

.collection-dropdown__item {
	padding: 0;
}

.collection-dropdown__label {
	display: flex;
	align-items: center;
	gap: .5rem;
	padding: .5rem 1rem;
	font-size: .875rem;
	color: var(--color-text, #3E2010);
	cursor: pointer;
	transition: background .1s;
}

.collection-dropdown__label:hover {
	background: var(--color-surface, #FFF8F0);
}

.collection-dropdown__check {
	accent-color: var(--color-primary, #8B4513);
	flex-shrink: 0;
}

.collection-dropdown__new-btn {
	display: block;
	width: 100%;
	padding: .5rem 1rem;
	background: none;
	border: none;
	border-top: 1px solid var(--color-border, #D4B896);
	color: var(--color-primary, #8B4513);
	font-size: .875rem;
	font-family: Lato, sans-serif;
	text-align: left;
	cursor: pointer;
	transition: background .1s;
}

.collection-dropdown__new-btn:hover {
	background: var(--color-surface, #FFF8F0);
}

.collection-dropdown__create-form {
	padding: .75rem 1rem;
	border-top: 1px solid var(--color-border, #D4B896);
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.collection-dropdown__name-input {
	width: 100%;
	padding: .4rem .6rem;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 4px;
	font-size: .875rem;
	font-family: Lato, sans-serif;
	color: var(--color-text, #3E2010);
	background: #fff;
}

.collection-dropdown__name-input:focus {
	outline: 2px solid var(--color-primary, #8B4513);
	outline-offset: 1px;
	border-color: var(--color-primary, #8B4513);
}

.collection-dropdown__private-label {
	display: flex;
	align-items: center;
	gap: .4rem;
	font-size: .8125rem;
	color: var(--color-text-muted, #8B6D5C);
	cursor: pointer;
}

.collection-dropdown__create-btn {
	padding: .35rem .75rem;
	background: var(--color-primary, #8B4513);
	border: none;
	border-radius: 4px;
	color: #fff;
	font-size: .875rem;
	font-family: Lato, sans-serif;
	cursor: pointer;
	align-self: flex-start;
	transition: background .15s;
}

.collection-dropdown__create-btn:hover {
	background: var(--color-kraft-dark, #5C3D24);
}

/* Position context for cards with dropdowns */
.recipe-card__footer {
	position: relative;
}

/* =========================================================
   Collections — My Account: toolbar + create form
   ========================================================= */

.collections-toolbar {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.25rem;
}

.collection-create-form {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: .6rem;
	padding: 1rem 1.25rem;
	background: var(--color-surface, #FFF8F0);
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 8px;
	margin-bottom: 1.25rem;
}

.collection-create-form .yr-collection-name {
	flex: 1 1 180px;
	padding: .45rem .65rem;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 4px;
	font-size: .9rem;
	font-family: Lato, sans-serif;
	color: var(--color-text, #3E2010);
	background: #fff;
}

.collection-create-form .yr-collection-name:focus {
	outline: 2px solid var(--color-primary, #8B4513);
	outline-offset: 1px;
	border-color: var(--color-primary, #8B4513);
}

.collection-create-form .yr-collection-private {
	padding: .45rem .6rem;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 4px;
	font-size: .9rem;
	font-family: Lato, sans-serif;
	color: var(--color-text, #3E2010);
	background: #fff;
}

/* =========================================================
   Collections — Collection card grid (My Account)
   ========================================================= */

.collection-card-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1rem;
}

.collection-card {
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 8px;
	background: #fff;
	overflow: hidden;
}

.collection-card__body {
	padding: 1rem;
	display: flex;
	flex-direction: column;
	gap: .75rem;
}

.collection-card__thumbs {
	display: flex;
	gap: .25rem;
}

.collection-card__thumb-img {
	width: 56px;
	height: 56px;
	object-fit: cover;
	border-radius: 4px;
	flex-shrink: 0;
}

.collection-card__thumb-placeholder {
	width: 56px;
	height: 56px;
	border-radius: 4px;
	background: var(--color-surface, #FFF8F0);
	border: 1px solid var(--color-border, #D4B896);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	flex-shrink: 0;
}

.collection-card__info {
	display: flex;
	flex-direction: column;
	gap: .2rem;
}

.collection-card__name-row {
	display: flex;
	align-items: center;
	gap: .3rem;
}

.collection-card__lock {
	font-size: .75rem;
	color: var(--color-text-muted, #8B6D5C);
	flex-shrink: 0;
}

.collection-card__name {
	font-weight: 600;
	font-size: .9375rem;
	color: var(--color-text, #3E2010);
	line-height: 1.3;
}

.collection-card__count {
	font-size: .8125rem;
	color: var(--color-text-muted, #8B6D5C);
}

.collection-card__actions {
	display: flex;
	align-items: center;
	gap: .5rem;
	flex-wrap: wrap;
}

.collection-card__link {
	font-size: .8125rem;
	color: var(--color-primary, #8B4513);
	text-decoration: none;
	font-weight: 600;
}

.collection-card__link:hover {
	text-decoration: underline;
}

.collection-card__btn {
	padding: .25rem .6rem;
	background: none;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 4px;
	font-size: .8125rem;
	font-family: Lato, sans-serif;
	color: var(--color-text-muted, #8B6D5C);
	cursor: pointer;
	transition: background .15s, border-color .15s, color .15s;
}

.collection-card__btn:hover {
	background: var(--color-surface, #FFF8F0);
	border-color: var(--color-text-muted, #8B6D5C);
	color: var(--color-text, #3E2010);
}

.collection-card__btn--danger {
	color: #c0392b;
	border-color: #e8bbb8;
}

.collection-card__btn--danger:hover {
	background: #fdf2f2;
	border-color: #c0392b;
	color: #c0392b;
}

.collection-card__edit-form {
	padding: .75rem 1rem;
	background: var(--color-surface, #FFF8F0);
	border-top: 1px solid var(--color-border, #D4B896);
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	align-items: center;
}

.collection-card__edit-form .yr-rename-input {
	flex: 1 1 140px;
	padding: .4rem .6rem;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 4px;
	font-size: .875rem;
	font-family: Lato, sans-serif;
	color: var(--color-text, #3E2010);
	background: #fff;
}

.collection-card__edit-form .yr-rename-input:focus {
	outline: 2px solid var(--color-primary, #8B4513);
	outline-offset: 1px;
	border-color: var(--color-primary, #8B4513);
}

.collection-card__edit-form .yr-privacy-select {
	padding: .4rem .5rem;
	border: 1px solid var(--color-border, #D4B896);
	border-radius: 4px;
	font-size: .875rem;
	font-family: Lato, sans-serif;
	color: var(--color-text, #3E2010);
	background: #fff;
}

/* =========================================================
   Collections — Collection page header
   ========================================================= */

.collection-header {
	margin-bottom: 2rem;
}

.collection-header__title {
	font-size: 2rem;
	color: var(--color-text, #3E2010);
	display: flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: .4rem;
}

.collection-header__meta {
	font-size: .9375rem;
	color: var(--color-text-muted, #8B6D5C);
}

.collection-header__meta a {
	color: var(--color-primary, #8B4513);
	font-weight: 600;
}

.collection-lock {
	font-size: .85em;
	color: var(--color-text-muted, #8B6D5C);
}

/* ── Add Recipe form: category groups ───────────────────────────────────── */
.mrf-category-groups {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 6px;
}
.mrf-category-group {
    background: #fafafa;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    padding: 10px 14px 12px;
    min-width: 160px;
}
.mrf-category-group__title {
    display: block;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #999;
    margin-bottom: 8px;
}
.mrf-category-group label {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 4px 0;
    cursor: pointer;
    font-size: 14px;
    color: #333;
}
.mrf-category-group label:hover {
    color: #8B4513;
}
.mrf-category-group input[type="checkbox"] {
    width: 15px;
    height: 15px;
    flex-shrink: 0;
    cursor: pointer;
}

/* ── Browse dropdown nav ─────────────────────────────────────────────────── */
.nav-browse {
    position: relative;
}
.nav-browse__toggle {
    display: flex;
    align-items: center;
    gap: 4px;
    background: none;
    border: none;
    cursor: pointer;
    font-size: inherit;
    font-family: inherit;
    font-weight: 500;
    color: inherit;
    padding: 0;
    line-height: 1;
}
.nav-browse__toggle:hover {
    opacity: 0.75;
}
.nav-browse__caret {
    transition: transform 0.15s ease;
}
.nav-browse__toggle[aria-expanded="true"] .nav-browse__caret {
    transform: rotate(180deg);
}
.nav-browse__dropdown {
    position: absolute;
    top: calc(100% + 12px);
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.10);
    min-width: 560px;
    z-index: 1000;
    padding: 20px 20px 14px;
}
.nav-browse__groups {
    display: flex;
    gap: 24px;
}
.nav-browse__group {
    flex: 1;
    min-width: 0;
}
.nav-browse__group-label {
    display: block;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: #999;
    margin-bottom: 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid #eee;
}
.nav-browse__link {
    display: block;
    padding: 5px 0;
    font-size: 14px;
    color: #333;
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.nav-browse__link:hover {
    color: #8B4513;
}
.nav-browse__footer {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid #eee;
}
.nav-browse__all {
    font-size: 13px;
    font-weight: 500;
    color: #8B4513;
    text-decoration: none;
}
.nav-browse__all:hover {
    text-decoration: underline;
}

/* ── Archive category filter group labels ───────────────────────────────── */
.category-filter__group-label {
    display: inline-block;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: #aaa;
    margin: 0 4px 0 12px;
    vertical-align: middle;
}

/* ── Recipe category tags on single recipe page ─────────────────────────── */
.recipe-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 10px;
}
.recipe-category-tag {
    display: inline-block;
    padding: 3px 10px;
    background: #f5f0eb;
    color: #8B4513;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s;
}
.recipe-category-tag:hover {
    background: #ede4d9;
}
