/*
Theme Name: Braai en Snaai Child
Template: astra
Version: 1.0.1
Description: Child thema voor Braai en Snaai BBQ affiliate website
Author: Braai en Snaai
Text Domain: braaiensnaai-child
*/

/* === main.css === */
:root {
	--color-primary: #e85d04;
	--color-secondary: #1a1a1a;
	--color-accent: #ffba08;
	--color-background: #fafaf8;
	--color-text: #2d2d2d;
	--color-light: #f5f0eb;
	--color-muted: #756f68;
	--color-border: #e4ded6;
	--color-white: #ffffff;
	--shadow-soft: 0 18px 40px rgba(26, 26, 26, 0.11);
	--shadow-card: 0 10px 26px rgba(26, 26, 26, 0.08);
	--font-heading: "Bebas Neue", "Oswald", Impact, sans-serif;
	--font-body: "Lora", Georgia, serif;
	--font-accent: "Oswald", Arial, sans-serif;
	--container: 1180px;
}

html {
	scroll-behavior: smooth;
}

body {
	background: var(--color-background);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.7;
	text-rendering: optimizeLegibility;
}

body.bns-menu-open {
	overflow: hidden;
}

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

a {
	color: var(--color-primary);
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.16em;
	transition: color 160ms ease, background-color 160ms ease, border-color 160ms ease, transform 160ms ease;
}

a:hover,
a:focus {
	color: #c24700;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--color-secondary);
	font-family: var(--font-heading);
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0 0 0.5em;
}

h1 {
	font-size: clamp(3rem, 9vw, 6.8rem);
}

h2 {
	font-size: clamp(2.3rem, 5vw, 4.1rem);
}

h3 {
	font-size: clamp(1.65rem, 3vw, 2.45rem);
}

p {
	margin: 0 0 1.25rem;
}

.bns-site-main {
	min-height: 70vh;
}

.bns-container {
	margin: 0 auto;
	max-width: var(--container);
	padding: 0 1.25rem;
	width: 100%;
}

.bns-section {
	padding: clamp(3rem, 7vw, 6rem) 0;
}

.bns-section--light {
	background: var(--color-light);
}

.bns-section--dark {
	background: var(--color-secondary);
	color: var(--color-white);
}

.bns-section--dark h2,
.bns-section--dark h3 {
	color: var(--color-white);
}

.bns-eyebrow {
	color: var(--color-primary);
	display: inline-flex;
	font-family: var(--font-accent);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin-bottom: 0.75rem;
	text-transform: uppercase;
}

.bns-lead {
	color: var(--color-muted);
	font-size: clamp(1.05rem, 2vw, 1.22rem);
	max-width: 720px;
}

.bns-section--dark .bns-lead {
	color: rgba(255, 255, 255, 0.78);
}

.bns-button,
.bns-cta,
.wp-block-button__link {
	align-items: center;
	background: var(--color-primary);
	border: 2px solid var(--color-primary);
	border-radius: 6px;
	color: var(--color-white);
	cursor: pointer;
	display: inline-flex;
	font-family: var(--font-accent);
	font-size: 0.98rem;
	font-weight: 700;
	gap: 0.45rem;
	justify-content: center;
	min-height: 44px;
	padding: 0.75rem 1.15rem;
	text-decoration: none;
	text-transform: uppercase;
}

.bns-button:hover,
.bns-button:focus,
.bns-cta:hover,
.bns-cta:focus,
.wp-block-button__link:hover,
.wp-block-button__link:focus {
	background: #c24700;
	border-color: #c24700;
	color: var(--color-white);
	transform: translateY(-1px);
}

.bns-button--ghost {
	background: transparent;
	border-color: rgba(255, 255, 255, 0.45);
	color: var(--color-white);
}

.bns-button--ghost:hover,
.bns-button--ghost:focus {
	background: var(--color-white);
	border-color: var(--color-white);
	color: var(--color-secondary);
}

.bns-grid {
	display: grid;
	gap: 1.5rem;
}

.bns-grid--2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bns-grid--3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.bns-grid--4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.bns-card {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-card);
	overflow: hidden;
}

.bns-card__media {
	aspect-ratio: 16 / 10;
	background:
		linear-gradient(135deg, rgba(232, 93, 4, 0.88), rgba(26, 26, 26, 0.82)),
		linear-gradient(45deg, #3b261f, #1a1a1a);
	position: relative;
}

.bns-card__media::after {
	background: repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.08) 1px, transparent 1px, transparent 10px);
	content: "";
	inset: 0;
	opacity: 0.22;
	position: absolute;
}

.bns-card__media img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.bns-card__body {
	padding: 1.25rem;
}

.bns-card__title {
	font-size: 2rem;
	margin-bottom: 0.55rem;
}

.bns-card__title a {
	color: var(--color-secondary);
	text-decoration: none;
}

.bns-card__title a:hover,
.bns-card__title a:focus {
	color: var(--color-primary);
}

.bns-meta {
	align-items: center;
	color: var(--color-muted);
	display: flex;
	flex-wrap: wrap;
	font-family: var(--font-accent);
	font-size: 0.88rem;
	gap: 0.75rem;
	text-transform: uppercase;
}

.bns-badge {
	background: var(--color-accent);
	border-radius: 999px;
	color: var(--color-secondary);
	display: inline-flex;
	font-family: var(--font-accent);
	font-size: 0.78rem;
	font-weight: 700;
	padding: 0.28rem 0.68rem;
	text-decoration: none;
	text-transform: uppercase;
}

.bns-placeholder-image {
	align-items: center;
	background:
		radial-gradient(circle at 24% 22%, rgba(255, 186, 8, 0.36), transparent 26%),
		linear-gradient(135deg, #2b1b17 0%, #1a1a1a 42%, #5d2b11 100%);
	color: var(--color-white);
	display: flex;
	font-family: var(--font-heading);
	font-size: clamp(2rem, 6vw, 5rem);
	justify-content: center;
	min-height: 320px;
	position: relative;
	text-align: center;
}

.bns-placeholder-image::before {
	background: repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.08) 1px, transparent 1px, transparent 14px);
	content: "";
	inset: 0;
	opacity: 0.23;
	position: absolute;
}

.bns-placeholder-image span {
	position: relative;
}

.bns-hero {
	background:
		linear-gradient(90deg, rgba(26, 26, 26, 0.91), rgba(26, 26, 26, 0.58)),
		radial-gradient(circle at 78% 26%, rgba(232, 93, 4, 0.58), transparent 28%),
		linear-gradient(135deg, #1a1a1a, #3a2216 58%, #0f0f0f);
	color: var(--color-white);
	min-height: min(760px, 86vh);
	padding: clamp(5rem, 10vw, 8rem) 0 clamp(3rem, 7vw, 5rem);
	position: relative;
}

.bns-hero::after {
	background: linear-gradient(180deg, transparent, rgba(250, 250, 248, 0.08));
	bottom: 0;
	content: "";
	height: 34%;
	left: 0;
	position: absolute;
	right: 0;
}

.bns-hero__inner {
	align-items: center;
	display: grid;
	gap: clamp(2rem, 6vw, 5rem);
	grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.7fr);
	position: relative;
	z-index: 1;
}

.bns-hero h1 {
	color: var(--color-white);
	max-width: 780px;
}

.bns-hero__copy {
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(1.08rem, 2vw, 1.28rem);
	max-width: 640px;
}

.bns-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.9rem;
	margin-top: 1.75rem;
}

.bns-hero__image {
	aspect-ratio: 4 / 5;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 8px;
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
	min-height: 380px;
	overflow: hidden;
}

.bns-category-tile {
	background: var(--color-secondary);
	border-radius: 8px;
	color: var(--color-white);
	display: flex;
	flex-direction: column;
	min-height: 210px;
	overflow: hidden;
	padding: 1.35rem;
	position: relative;
	text-decoration: none;
}

.bns-category-tile::before {
	background: linear-gradient(135deg, rgba(232, 93, 4, 0.85), rgba(255, 186, 8, 0.28));
	content: "";
	inset: auto 0 0;
	height: 46%;
	position: absolute;
	transform: skewY(-7deg);
	transform-origin: left bottom;
}

.bns-category-tile:hover,
.bns-category-tile:focus {
	color: var(--color-white);
	transform: translateY(-3px);
}

.bns-category-tile__title,
.bns-category-tile__text,
.bns-category-tile__link {
	position: relative;
	z-index: 1;
}

.bns-category-tile__title {
	color: var(--color-white);
	font-size: 2.6rem;
	margin-top: auto;
}

.bns-category-tile__text {
	color: rgba(255, 255, 255, 0.78);
	margin-bottom: 1rem;
}

.bns-category-tile__link {
	font-family: var(--font-accent);
	font-weight: 700;
	text-transform: uppercase;
}

.bns-newsletter {
	align-items: center;
	display: grid;
	gap: 2rem;
	grid-template-columns: minmax(0, 0.85fr) minmax(280px, 0.65fr);
}

.bns-newsletter-form {
	background: var(--color-white);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 8px;
	box-shadow: var(--shadow-soft);
	display: grid;
	gap: 0.85rem;
	padding: 1.2rem;
}

.bns-newsletter-form label {
	color: var(--color-secondary);
	font-family: var(--font-accent);
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
}

.bns-newsletter-form input[type="email"],
.bns-newsletter-form input[type="text"],
.bns-search-form input[type="search"],
.search-form input[type="search"] {
	background: var(--color-background);
	border: 1px solid var(--color-border);
	border-radius: 6px;
	color: var(--color-text);
	min-height: 48px;
	padding: 0.75rem 0.9rem;
	width: 100%;
}

.bns-newsletter-form input:focus,
.bns-search-form input:focus,
.search-form input:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(232, 93, 4, 0.15);
	outline: none;
}

.bns-widget {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-card);
	padding: 1.25rem;
}

.bns-widget + .bns-widget {
	margin-top: 1.2rem;
}

.bns-widget h3 {
	font-size: 1.9rem;
}

.bns-list-plain {
	list-style: none;
	margin: 0;
	padding: 0;
}

.bns-list-plain li + li {
	border-top: 1px solid var(--color-border);
	margin-top: 0.75rem;
	padding-top: 0.75rem;
}

.bns-screen-reader-text,
.screen-reader-text {
	border: 0;
	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;
}

@media (max-width: 980px) {
	.bns-grid--3,
	.bns-grid--4,
	.bns-hero__inner,
	.bns-newsletter {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.bns-hero__image {
		min-height: 300px;
	}
}

@media (max-width: 720px) {
	.bns-container {
		padding: 0 1rem;
	}

	.bns-grid--2,
	.bns-grid--3,
	.bns-grid--4,
	.bns-hero__inner,
	.bns-newsletter {
		grid-template-columns: 1fr;
	}

	.bns-hero {
		min-height: auto;
		padding-top: 4.5rem;
	}

	.bns-hero__actions {
		align-items: stretch;
		flex-direction: column;
	}

	.bns-button,
	.bns-cta {
		width: 100%;
	}

	.bns-category-tile {
		min-height: 180px;
	}
}

/* === header.css === */
.bns-site-header {
	background: rgba(26, 26, 26, 0.98);
	left: 0;
	position: sticky;
	right: 0;
	top: 0;
	transition: box-shadow 180ms ease, border-color 180ms ease;
	width: 100%;
	z-index: 1000;
}

.bns-site-header.is-scrolled {
	border-bottom: 3px solid var(--color-primary);
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.2);
}

.bns-header__inner {
	align-items: center;
	display: grid;
	gap: 1rem;
	grid-template-columns: auto minmax(0, 1fr) auto;
	margin: 0 auto;
	max-width: var(--container);
	min-height: 76px;
	padding: 0 1.25rem;
	position: relative;
}

.bns-logo {
	align-items: center;
	color: var(--color-white);
	display: inline-flex;
	font-family: var(--font-heading);
	font-size: clamp(2rem, 4vw, 3rem);
	gap: 0.28rem;
	letter-spacing: 0;
	line-height: 0.9;
	text-decoration: none;
	white-space: nowrap;
}

.bns-logo span:nth-child(2) {
	color: var(--color-accent);
	font-size: 0.72em;
}

.bns-logo:hover,
.bns-logo:focus {
	color: var(--color-white);
}

.bns-primary-nav {
	justify-self: end;
}

.bns-menu {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.bns-menu li {
	position: relative;
}

.bns-menu a {
	align-items: center;
	border-radius: 6px;
	color: rgba(255, 255, 255, 0.86);
	display: inline-flex;
	font-family: var(--font-accent);
	font-size: 0.92rem;
	font-weight: 700;
	min-height: 44px;
	padding: 0.55rem 0.82rem;
	text-decoration: none;
	text-transform: uppercase;
}

.bns-menu a:hover,
.bns-menu a:focus,
.bns-menu .current-menu-item > a,
.bns-menu .current_page_item > a {
	background: rgba(232, 93, 4, 0.16);
	color: var(--color-accent);
}

.bns-menu .sub-menu {
	background: var(--color-secondary);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 8px;
	box-shadow: 0 16px 34px rgba(0, 0, 0, 0.28);
	left: 0;
	list-style: none;
	margin: 0;
	min-width: 220px;
	opacity: 0;
	padding: 0.45rem;
	pointer-events: none;
	position: absolute;
	top: calc(100% + 0.35rem);
	transform: translateY(8px);
	transition: opacity 160ms ease, transform 160ms ease;
}

.bns-menu li:hover > .sub-menu,
.bns-menu li:focus-within > .sub-menu {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.bns-menu .sub-menu a {
	justify-content: flex-start;
	width: 100%;
}

.bns-header__actions {
	align-items: center;
	display: flex;
	gap: 0.45rem;
}

.bns-icon-button {
	align-items: center;
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 6px;
	color: var(--color-white);
	cursor: pointer;
	display: inline-flex;
	height: 44px;
	justify-content: center;
	padding: 0;
	width: 44px;
}

.bns-icon-button:hover,
.bns-icon-button:focus,
.bns-icon-button[aria-expanded="true"] {
	background: var(--color-primary);
	border-color: var(--color-primary);
	outline: none;
}

.bns-icon--search {
	border: 2px solid currentColor;
	border-radius: 999px;
	display: inline-block;
	height: 16px;
	position: relative;
	width: 16px;
}

.bns-icon--search::after {
	background: currentColor;
	content: "";
	height: 8px;
	position: absolute;
	right: -5px;
	top: 10px;
	transform: rotate(45deg);
	width: 2px;
}

.bns-menu-bars {
	display: grid;
	gap: 4px;
	width: 20px;
}

.bns-menu-bars span {
	background: currentColor;
	border-radius: 999px;
	display: block;
	height: 2px;
	width: 20px;
}

.bns-menu-toggle {
	display: none;
}

.bns-header-search {
	background: var(--color-secondary);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 8px;
	box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
	min-width: min(420px, calc(100vw - 2rem));
	padding: 0.9rem;
	position: absolute;
	right: 1.25rem;
	top: calc(100% + 0.65rem);
	z-index: 10;
}

.bns-header-search .search-form,
.bns-header-search form {
	display: flex;
	gap: 0.5rem;
}

.bns-header-search input[type="search"] {
	background: var(--color-white);
	min-width: 0;
}

.bns-header-search input[type="submit"],
.bns-header-search button[type="submit"] {
	background: var(--color-primary);
	border: 0;
	border-radius: 6px;
	color: var(--color-white);
	cursor: pointer;
	font-family: var(--font-accent);
	font-weight: 700;
	min-height: 44px;
	padding: 0.65rem 0.95rem;
	text-transform: uppercase;
}

@media (max-width: 920px) {
	.bns-header__inner {
		grid-template-columns: auto auto;
		justify-content: space-between;
	}

	.bns-primary-nav {
		background: var(--color-secondary);
		border-top: 1px solid rgba(255, 255, 255, 0.12);
		box-shadow: 0 24px 40px rgba(0, 0, 0, 0.32);
		display: none;
		grid-column: 1 / -1;
		margin: 0 -1.25rem;
		padding: 0.75rem 1.25rem 1rem;
		width: calc(100% + 2.5rem);
	}

	.bns-primary-nav.is-open {
		display: block;
	}

	.bns-menu {
		align-items: stretch;
		display: grid;
		gap: 0.25rem;
	}

	.bns-menu a {
		justify-content: space-between;
		width: 100%;
	}

	.bns-menu .sub-menu {
		border: 0;
		box-shadow: none;
		display: grid;
		margin: 0.2rem 0 0.4rem 0.8rem;
		opacity: 1;
		padding: 0;
		pointer-events: auto;
		position: static;
		transform: none;
	}

	.bns-menu-toggle {
		display: inline-flex;
	}
}

@media (max-width: 560px) {
	.bns-header__inner {
		min-height: 68px;
		padding: 0 1rem;
	}

	.bns-logo {
		font-size: 2rem;
	}

	.bns-header-search {
		left: 1rem;
		min-width: auto;
		right: 1rem;
	}
}

/* === footer.css === */
.bns-site-footer {
	background: var(--color-secondary);
	color: rgba(255, 255, 255, 0.76);
	padding: clamp(3rem, 7vw, 5rem) 0 1.4rem;
}

.bns-footer__grid {
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	grid-template-columns: 1.15fr 0.75fr 0.9fr 0.75fr;
}

.bns-footer__column h2 {
	color: var(--color-white);
	font-size: 2rem;
	margin-bottom: 0.65rem;
}

.bns-footer__column p {
	margin: 0;
	max-width: 30rem;
}

.bns-footer__column ul,
.bns-footer-menu,
.bns-social-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.bns-footer__column li + li,
.bns-footer-menu li + li,
.bns-social-links li + li {
	margin-top: 0.45rem;
}

.bns-site-footer a {
	color: rgba(255, 255, 255, 0.82);
	text-decoration: none;
}

.bns-site-footer a:hover,
.bns-site-footer a:focus {
	color: var(--color-accent);
}

.bns-footer__bottom {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	margin-top: clamp(2rem, 5vw, 3.5rem);
	padding-top: 1.25rem;
}

.bns-footer__bottom p {
	font-size: 0.92rem;
	margin: 0;
	max-width: 720px;
}

.bns-footer__bottom nav {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	justify-content: flex-end;
}

.bns-footer__bottom nav a {
	font-family: var(--font-accent);
	font-size: 0.84rem;
	font-weight: 700;
	text-transform: uppercase;
	white-space: nowrap;
}

.bns-awin-pixel {
	display: none;
}

@media (max-width: 900px) {
	.bns-footer__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.bns-footer__bottom {
		align-items: flex-start;
		flex-direction: column;
	}

	.bns-footer__bottom nav {
		justify-content: flex-start;
	}
}

@media (max-width: 560px) {
	.bns-footer__grid {
		grid-template-columns: 1fr;
	}
}

/* === blog.css === */
.bns-blog-hero {
	background:
		linear-gradient(90deg, rgba(26, 26, 26, 0.9), rgba(26, 26, 26, 0.56)),
		linear-gradient(135deg, #1a1a1a, #4a2413);
	color: var(--color-white);
	padding: clamp(4rem, 8vw, 6rem) 0;
}

.bns-blog-hero h1 {
	color: var(--color-white);
	max-width: 850px;
}

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

.bns-category-filter a {
	align-items: center;
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	color: var(--color-text);
	display: inline-flex;
	font-family: var(--font-accent);
	font-size: 0.88rem;
	font-weight: 700;
	min-height: 44px;
	padding: 0.48rem 0.9rem;
	text-decoration: none;
	text-transform: uppercase;
}

.bns-category-filter a:hover,
.bns-category-filter a:focus,
.bns-category-filter a.is-active {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

.bns-blog__layout {
	align-items: start;
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	grid-template-columns: minmax(0, 1fr) 320px;
}

.bns-post-grid {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bns-post-card {
	display: flex;
	flex-direction: column;
}

.bns-post-card .bns-card__media {
	display: block;
}

.bns-post-card .bns-badge {
	margin-bottom: 0.75rem;
}

.bns-post-card__excerpt {
	color: var(--color-muted);
	margin-top: 0.75rem;
}

.bns-post-card__excerpt p:last-child {
	margin-bottom: 0;
}

.bns-post-card__link {
	align-items: center;
	color: var(--color-primary);
	display: inline-flex;
	font-family: var(--font-accent);
	font-weight: 700;
	gap: 0.35rem;
	margin-top: 1rem;
	text-decoration: none;
	text-transform: uppercase;
}

.bns-blog-sidebar {
	position: sticky;
	top: 104px;
}

.bns-blog-sidebar .bns-affiliate-box {
	grid-template-columns: 1fr;
}

.bns-blog-sidebar .bns-affiliate-box__action {
	justify-items: stretch;
}

.bns-blog-sidebar .bns-affiliate-box__action p {
	text-align: left;
}

.bns-pagination {
	margin-top: 2rem;
}

.bns-pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}

.bns-pagination .page-numbers {
	align-items: center;
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 6px;
	color: var(--color-text);
	display: inline-flex;
	font-family: var(--font-accent);
	font-weight: 700;
	justify-content: center;
	min-height: 44px;
	min-width: 44px;
	padding: 0.45rem 0.72rem;
	text-decoration: none;
}

.bns-pagination .page-numbers.current,
.bns-pagination .page-numbers:hover,
.bns-pagination .page-numbers:focus {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

@media (max-width: 980px) {
	.bns-blog__layout {
		grid-template-columns: 1fr;
	}

	.bns-blog-sidebar {
		position: static;
	}
}

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

/* === single.css === */
.bns-single {
	background: var(--color-background);
}

.bns-single__layout {
	align-items: start;
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	grid-template-columns: minmax(0, 7fr) minmax(260px, 3fr);
}

.bns-article {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-card);
	padding: clamp(1.25rem, 4vw, 3rem);
}

.bns-article__header {
	margin-bottom: 1.4rem;
}

.bns-article__header h1 {
	margin-top: 0.45rem;
}

.bns-article__image {
	aspect-ratio: 16 / 9;
	border-radius: 8px;
	margin: 0 0 1.5rem;
	overflow: hidden;
}

.bns-article__image img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.bns-article__intro {
	border-left: 4px solid var(--color-primary);
	color: #45413d;
	font-size: 1.15rem;
	font-weight: 600;
	margin: 1.5rem 0;
	padding-left: 1rem;
}

.bns-article__intro p:last-child {
	margin-bottom: 0;
}

.bns-toc {
	background: var(--color-light);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	margin: 2rem 0;
	padding: 1rem 1.1rem;
}

.bns-toc h2 {
	font-size: 1.8rem;
	margin-bottom: 0.75rem;
}

.bns-toc__list {
	display: grid;
	gap: 0.35rem;
	margin: 0;
	padding-left: 1.2rem;
}

.bns-toc__item--h3 {
	margin-left: 1rem;
}

.bns-toc a {
	color: var(--color-text);
	text-decoration: none;
}

.bns-toc a:hover,
.bns-toc a:focus {
	color: var(--color-primary);
}

.bns-article-content {
	font-size: 1.04rem;
}

.bns-article-content h2,
.bns-article-content h3 {
	margin-top: 1.45em;
}

.bns-article-content h2 {
	border-bottom: 2px solid rgba(232, 93, 4, 0.18);
	padding-bottom: 0.25rem;
}

.bns-article-content ul,
.bns-article-content ol {
	margin-bottom: 1.25rem;
	padding-left: 1.25rem;
}

.bns-article-content blockquote {
	background: var(--color-light);
	border-left: 4px solid var(--color-accent);
	border-radius: 0 8px 8px 0;
	color: #3d3935;
	font-size: 1.15rem;
	margin: 1.5rem 0;
	padding: 1rem 1.2rem;
}

.bns-article-content table {
	border-collapse: collapse;
	display: block;
	margin: 1.5rem 0;
	overflow-x: auto;
	width: 100%;
}

.bns-article-content th,
.bns-article-content td {
	border: 1px solid var(--color-border);
	padding: 0.7rem;
	text-align: left;
}

.bns-article-content th {
	background: var(--color-light);
	font-family: var(--font-accent);
	text-transform: uppercase;
}

.bns-article__footer {
	border-top: 1px solid var(--color-border);
	display: grid;
	gap: 1rem;
	margin-top: 2rem;
	padding-top: 1.25rem;
}

.bns-share {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
}

.bns-share span {
	color: var(--color-muted);
	font-family: var(--font-accent);
	font-weight: 700;
	text-transform: uppercase;
}

.bns-share a,
.bns-tags a {
	background: var(--color-light);
	border-radius: 999px;
	color: var(--color-text);
	display: inline-flex;
	font-family: var(--font-accent);
	font-size: 0.84rem;
	font-weight: 700;
	min-height: 36px;
	padding: 0.42rem 0.75rem;
	text-decoration: none;
	text-transform: uppercase;
}

.bns-share a:hover,
.bns-share a:focus,
.bns-tags a:hover,
.bns-tags a:focus {
	background: var(--color-primary);
	color: var(--color-white);
}

.bns-sidebar {
	position: sticky;
	top: 104px;
}

.bns-sidebar .bns-affiliate-box {
	grid-template-columns: 1fr;
}

.bns-sidebar .bns-affiliate-box__action {
	justify-items: stretch;
}

.bns-sidebar .bns-affiliate-box__action p {
	text-align: left;
}

.bns-related {
	margin-top: clamp(2rem, 6vw, 4rem);
}

.bns-related h2 {
	margin-bottom: 1rem;
}

.bns-breadcrumbs {
	color: var(--color-muted);
	font-family: var(--font-accent);
	font-size: 0.88rem;
	font-weight: 700;
	margin-bottom: 1rem;
	text-transform: uppercase;
}

.bns-breadcrumbs a {
	color: var(--color-muted);
	text-decoration: none;
}

.bns-breadcrumbs a:hover,
.bns-breadcrumbs a:focus {
	color: var(--color-primary);
}

@media (max-width: 940px) {
	.bns-single__layout {
		grid-template-columns: 1fr;
	}

	.bns-sidebar {
		position: static;
	}
}

@media print {
	.bns-site-header,
	.bns-site-footer,
	.bns-sidebar,
	.bns-share,
	.bns-affiliate-box,
	.bns-related {
		display: none;
	}

	.bns-article {
		border: 0;
		box-shadow: none;
		padding: 0;
	}
}

/* === affiliate.css === */
.bns-affiliate-box {
	align-items: center;
	background: var(--color-white);
	border: 2px solid rgba(232, 93, 4, 0.22);
	border-radius: 8px;
	box-shadow: var(--shadow-soft);
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 150px minmax(0, 1fr) auto;
	margin: 2rem 0;
	padding: 1rem;
	position: relative;
}

.bns-affiliate-box::before {
	background: var(--color-primary);
	border-radius: 8px 0 0 8px;
	content: "";
	inset: -2px auto -2px -2px;
	position: absolute;
	width: 6px;
}

.bns-affiliate-box__image {
	align-items: center;
	aspect-ratio: 1;
	background:
		radial-gradient(circle at 28% 24%, rgba(255, 186, 8, 0.55), transparent 32%),
		linear-gradient(135deg, #1a1a1a, #5a260e);
	border-radius: 8px;
	color: var(--color-white);
	display: flex;
	font-family: var(--font-heading);
	font-size: 2.5rem;
	justify-content: center;
	overflow: hidden;
}

.bns-affiliate-box__image img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.bns-affiliate-box__label {
	color: var(--color-primary);
	font-family: var(--font-accent);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0 0 0.2rem;
	text-transform: uppercase;
}

.bns-affiliate-box__title {
	font-size: clamp(2rem, 4vw, 3rem);
	margin-bottom: 0.3rem;
}

.bns-affiliate-box__description {
	color: var(--color-muted);
	margin-bottom: 0.65rem;
}

.bns-affiliate-box__meta {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
}

.bns-affiliate-box__price {
	color: var(--color-secondary);
	font-family: var(--font-accent);
	font-size: 1.2rem;
}

.bns-affiliate-box__action {
	display: grid;
	gap: 0.45rem;
	justify-items: end;
	min-width: 180px;
}

.bns-affiliate-box__action p {
	color: var(--color-muted);
	font-size: 0.78rem;
	line-height: 1.35;
	margin: 0;
	text-align: right;
}

.bns-stars {
	color: #bcb5ac;
	display: inline-block;
	font-family: Arial, sans-serif;
	font-size: 1rem;
	letter-spacing: 0;
	line-height: 1;
	position: relative;
}

.bns-stars__base,
.bns-stars__fill {
	display: block;
	white-space: nowrap;
}

.bns-stars__fill {
	color: var(--color-accent);
	inset: 0 auto auto 0;
	overflow: hidden;
	position: absolute;
}

.bns-affiliate-disclaimer {
	background: #fff7eb;
	border: 1px solid rgba(232, 93, 4, 0.32);
	border-radius: 8px;
	color: var(--color-text);
	font-size: 0.95rem;
	margin: 1.25rem 0;
	padding: 0.85rem 1rem;
}

@media (max-width: 820px) {
	.bns-affiliate-box {
		grid-template-columns: 110px minmax(0, 1fr);
	}

	.bns-affiliate-box__action {
		grid-column: 1 / -1;
		justify-items: stretch;
		min-width: 0;
	}

	.bns-affiliate-box__action p {
		text-align: left;
	}
}

@media (max-width: 560px) {
	.bns-affiliate-box {
		grid-template-columns: 1fr;
	}

	.bns-affiliate-box__image {
		aspect-ratio: 16 / 9;
	}
}

.bns-recipe-card {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-card);
	margin: 2rem 0;
	overflow: hidden;
}

.bns-recipe-card__header {
	align-items: start;
	background: var(--color-light);
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	padding: clamp(1.25rem, 3vw, 2rem);
}

.bns-recipe-card__header h2 {
	margin-bottom: 0.4rem;
}

.bns-recipe-card__header p {
	color: var(--color-muted);
	margin-bottom: 0;
	max-width: 720px;
}

.bns-recipe-card__meta {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.bns-recipe-card__meta div {
	border-right: 1px solid var(--color-border);
	padding: 1rem;
}

.bns-recipe-card__meta div:last-child {
	border-right: 0;
}

.bns-recipe-card__meta span {
	color: var(--color-muted);
	display: block;
	font-family: var(--font-accent);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
}

.bns-recipe-card__meta strong {
	color: var(--color-secondary);
	font-family: var(--font-heading);
	font-size: 1.8rem;
	font-weight: 400;
}

.bns-recipe-card__body {
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	grid-template-columns: minmax(220px, 0.85fr) minmax(0, 1.25fr);
	padding: clamp(1.25rem, 3vw, 2rem);
}

.bns-recipe-card__body h3,
.bns-recipe-card__nutrition h3 {
	font-size: 2rem;
}

.bns-ingredient-list,
.bns-instruction-list,
.bns-recipe-card__nutrition ul {
	margin: 0;
	padding-left: 1.25rem;
}

.bns-ingredient-list li,
.bns-instruction-list li {
	margin-bottom: 0.65rem;
}

.bns-instruction-list li::marker {
	color: var(--color-primary);
	font-family: var(--font-accent);
	font-weight: 700;
}

.bns-recipe-card__nutrition {
	border-top: 1px solid var(--color-border);
	padding: 1.25rem clamp(1.25rem, 3vw, 2rem);
}

@media (max-width: 760px) {
	.bns-recipe-card__header {
		display: grid;
	}

	.bns-recipe-card__meta,
	.bns-recipe-card__body {
		grid-template-columns: 1fr;
	}

	.bns-recipe-card__meta div {
		border-bottom: 1px solid var(--color-border);
		border-right: 0;
	}
}

.bns-product-review {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	box-shadow: var(--shadow-soft);
	display: grid;
	gap: clamp(1.25rem, 4vw, 2rem);
	grid-template-columns: minmax(240px, 0.75fr) minmax(0, 1.25fr);
	margin: 2rem 0;
	overflow: hidden;
	padding: clamp(1rem, 3vw, 1.5rem);
}

.bns-product-review__media {
	align-items: center;
	background:
		radial-gradient(circle at 28% 22%, rgba(255, 186, 8, 0.46), transparent 32%),
		linear-gradient(135deg, #1a1a1a, #6a2d12);
	border-radius: 8px;
	color: var(--color-white);
	display: flex;
	font-family: var(--font-heading);
	font-size: 3rem;
	justify-content: center;
	min-height: 320px;
	overflow: hidden;
}

.bns-product-review__media img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.bns-product-review__content h2 {
	margin-bottom: 0.4rem;
}

.bns-product-review__content > p {
	color: var(--color-muted);
}

.bns-product-review__rating,
.bns-product-review__price {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin: 0.8rem 0;
}

.bns-product-review__rating strong,
.bns-product-review__price strong {
	color: var(--color-secondary);
	font-family: var(--font-accent);
	font-size: 1.15rem;
}

.bns-product-review__price span {
	color: var(--color-muted);
	font-family: var(--font-accent);
	font-size: 0.84rem;
	font-weight: 700;
	text-transform: uppercase;
}

.bns-product-review__lists {
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin: 1.25rem 0;
}

.bns-product-review__lists section {
	background: var(--color-light);
	border-radius: 8px;
	padding: 1rem;
}

.bns-product-review__lists h3 {
	font-size: 1.8rem;
}

.bns-pro-list,
.bns-con-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.bns-pro-list li,
.bns-con-list li {
	padding-left: 1.4rem;
	position: relative;
}

.bns-pro-list li + li,
.bns-con-list li + li {
	margin-top: 0.55rem;
}

.bns-pro-list li::before,
.bns-con-list li::before {
	border-radius: 999px;
	content: "";
	height: 0.55rem;
	left: 0;
	position: absolute;
	top: 0.55rem;
	width: 0.55rem;
}

.bns-pro-list li::before {
	background: #1f8f4a;
}

.bns-con-list li::before {
	background: var(--color-primary);
}

.bns-product-review__cta {
	font-size: 1.05rem;
	width: 100%;
}

.bns-product-review__disclaimer {
	color: var(--color-muted);
	font-size: 0.86rem;
	line-height: 1.45;
	margin: 0.75rem 0 0;
}

@media (max-width: 820px) {
	.bns-product-review,
	.bns-product-review__lists {
		grid-template-columns: 1fr;
	}

	.bns-product-review__media {
		min-height: 240px;
	}
}

