/* =========================================================================
   Kitchen Punks — supplemental styling
   theme.json carries tokens, type roles and block defaults; this file carries
   the editorial layout devices that presets can't express.
   ========================================================================= */

:root {
	--kp-ease: cubic-bezier(.16, 1, .3, 1);
}

::selection { background: var(--wp--preset--color--accent); color: #fff; }

:where(a):focus-visible,
:where(button):focus-visible,
:where(input):focus-visible {
	outline: 2.5px solid var(--wp--preset--color--accent);
	outline-offset: 3px;
	border-radius: 1px;
}

/* ---- Thin running top bar (the "field log" strip) --------------------- */
.kp-topbar {
	background: var(--wp--preset--color--contrast);
	color: #e9eadf;
	font-family: var(--wp--preset--font-family--mono);
	font-size: .7rem;
	letter-spacing: .04em;
}
.kp-topbar a { color: #e9eadf; text-decoration: none; }
.kp-topbar a:hover { color: var(--wp--preset--color--accent); }
.kp-topbar strong { color: var(--wp--preset--color--accent); font-weight: 700; }

/* ---- Site header ----------------------------------------------------- */
.kp-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: color-mix(in srgb, var(--wp--preset--color--base) 88%, transparent);
	-webkit-backdrop-filter: saturate(1.4) blur(8px);
	backdrop-filter: saturate(1.4) blur(8px);
	border-bottom: 1px solid var(--wp--preset--color--hairline);
}
/* olive accent on the leading glyph of the wordmark */
.wp-block-site-title a::first-letter { color: var(--wp--preset--color--primary); }

.kp-nav a {
	font-family: var(--wp--preset--font-family--grotesk);
	font-weight: 500;
	font-size: .92rem;
	text-decoration: none;
	color: var(--wp--preset--color--contrast);
}
.kp-nav a:hover { color: var(--wp--preset--color--primary-deep); }
.kp-nav .current-menu-item a { color: var(--wp--preset--color--muted); }

/* ---- Eyebrow / section line (mono kicker with a rule) ----------------- */
.kp-eyebrow {
	font-family: var(--wp--preset--font-family--mono);
	font-size: .72rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--primary-deep);
	display: flex;
	align-items: center;
	gap: .8rem;
}
.kp-eyebrow::before {
	content: "";
	width: 2.4rem;
	height: 1.5px;
	background: var(--wp--preset--color--primary);
}

/* ---- Editorial feed: a list, not a card grid ------------------------- */
.kp-feed > li,
.kp-feed > .wp-block-post {
	border-top: 1.5px solid var(--wp--preset--color--contrast);
	padding-top: 1.4rem;
	margin-bottom: 2.8rem;
	list-style: none;
}
.kp-feed .wp-block-post-title {
	margin: .2rem 0 .5rem;
	line-height: 1.06;
	letter-spacing: -.02em;
}
.kp-feed .wp-block-post-title a { text-decoration: none; }
.kp-feed .wp-block-post-title a:hover { color: var(--wp--preset--color--accent); }
.kp-feed .wp-block-post-excerpt__excerpt { color: #3a3a3a; }

/* meta row — date · categories, all mono */
.kp-meta {
	font-family: var(--wp--preset--font-family--mono);
	font-size: .72rem;
	letter-spacing: .04em;
	color: var(--wp--preset--color--muted);
	text-transform: uppercase;
}
.kp-meta .wp-block-post-date,
.kp-meta .wp-block-post-terms { color: var(--wp--preset--color--muted); }
.kp-meta a { color: var(--wp--preset--color--primary-deep); }

/* featured thumb sits quiet, not a glossy card */
.kp-feed .wp-block-post-featured-image img {
	border-radius: 2px;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}

/* ---- Sidebar --------------------------------------------------------- */
.kp-sidebar { font-size: .95rem; }
.kp-sidebar .kp-widget { margin-bottom: 2.6rem; }
.kp-sidebar .kp-widget-title,
.kp-sidebar .wp-block-heading {
	font-family: var(--wp--preset--font-family--mono);
	font-size: .72rem;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--contrast);
	border-top: 1.5px solid var(--wp--preset--color--contrast);
	padding-top: .5rem;
	margin-bottom: 1rem;
}
.kp-sidebar ul { list-style: none; padding: 0; margin: 0; }
.kp-sidebar li { padding: .4rem 0; border-bottom: 1px solid var(--wp--preset--color--hairline); }
.kp-sidebar li a { text-decoration: none; }
.kp-sidebar li a:hover { color: var(--wp--preset--color--accent); }
.kp-sidebar .wp-block-categories li,
.kp-sidebar .wp-block-latest-posts li { display: flex; justify-content: space-between; gap: .5rem; }
.kp-sidebar .wp-block-tag-cloud a {
	font-family: var(--wp--preset--font-family--mono) !important;
	font-size: .72rem !important;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--wp--preset--color--primary-deep);
	border: 1px solid var(--wp--preset--color--hairline);
	border-radius: 2px;
	padding: .2rem .5rem;
	margin: 0 .25rem .4rem 0;
	display: inline-block;
	text-decoration: none;
}
.kp-sidebar .wp-block-tag-cloud a:hover { border-color: var(--wp--preset--color--accent); color: var(--wp--preset--color--accent); }

/* sticky sidebar on wide screens */
@media (min-width: 782px) {
	.kp-sidebar { position: sticky; top: 5rem; align-self: start; }
}

/* search field — mono, hairline */
.wp-block-search__input {
	border: 1px solid var(--wp--preset--color--hairline) !important;
	border-radius: 2px;
	font-family: var(--wp--preset--font-family--mono);
	font-size: .82rem;
}
.wp-block-search__button {
	background: var(--wp--preset--color--primary) !important;
	color: #fff !important;
	border-radius: 2px;
	font-family: var(--wp--preset--font-family--grotesk);
}

/* ---- Single post: keep prose measure, italic asides --------------- */
.kp-article .wp-block-post-content { max-width: 68ch; }
.kp-article blockquote {
	border-left: 2px solid var(--wp--preset--color--primary);
	padding-left: 1.2rem;
	font-style: italic;
	color: #3a3a3a;
}

/* ---- Footer ---------------------------------------------------------- */
.kp-footer {
	border-top: 1px solid var(--wp--preset--color--hairline);
	font-family: var(--wp--preset--font-family--mono);
	font-size: .74rem;
	color: var(--wp--preset--color--muted);
}
.kp-footer a { color: var(--wp--preset--color--muted); text-decoration: none; }
.kp-footer a:hover { color: var(--wp--preset--color--accent); }

@media (prefers-reduced-motion: reduce) {
	* { scroll-behavior: auto !important; }
}
