/**
 * Recipe catalog + single recipe. Reuses the global :root --nn-* design tokens
 * defined by the theme. Mobile-first, breakpoints at 600 / 940px like the blog.
 */

/* ---------- Catalog ---------- */
.nn-recipes {
	max-width: 1120px;
	margin: 0 auto;
	padding: 2rem 1.1rem 3.5rem;
}
.nn-recipes__head {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 1.75rem;
}
.nn-recipes__title {
	font-size: clamp(1.8rem, 5vw, 2.6rem);
	line-height: 1.1;
	margin: .35rem 0 .6rem;
	color: var(--nn-ink);
}
.nn-recipes__intro {
	color: var(--nn-muted);
	font-size: 1.02rem;
	line-height: 1.6;
	margin: 0;
}
.nn-recipes .nn-breadcrumb {
	justify-content: center;
}

/* Search */
.nn-recipes-search {
	position: relative;
	max-width: 640px;
	margin: 0 auto 1.1rem;
}
.nn-recipes-search__field {
	display: flex;
	align-items: center;
	gap: .6rem;
	background: #fff;
	border: 2px solid var(--nn-border);
	border-radius: var(--nn-r-pill);
	padding: .35rem .5rem .35rem 1rem;
	box-shadow: var(--nn-shadow-sm);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.nn-recipes-search__field:focus-within {
	border-color: var(--nn-emerald);
	box-shadow: 0 0 0 4px var(--nn-emerald-soft);
}
.nn-recipes-search__field .nn-ricon {
	width: 1.25rem;
	height: 1.25rem;
	color: var(--nn-emerald);
	flex: none;
}
.nn-recipes-search__input {
	flex: 1;
	border: 0;
	outline: 0;
	background: transparent;
	font-size: 1rem;
	padding: .55rem 0;
	color: var(--nn-ink);
	min-width: 0;
}
.nn-recipes-search__clear {
	border: 0;
	background: var(--nn-soft);
	color: var(--nn-muted);
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	font-size: 1.3rem;
	line-height: 1;
	cursor: pointer;
	flex: none;
}
.nn-recipes-search__clear:hover {
	background: var(--nn-emerald-soft);
	color: var(--nn-emerald-dark);
}
.nn-recipes-suggest {
	position: absolute;
	top: calc(100% + .4rem);
	left: 0;
	right: 0;
	z-index: 30;
	margin: 0;
	padding: .35rem;
	list-style: none;
	background: #fff;
	border: 1px solid var(--nn-border);
	border-radius: var(--nn-r-md);
	box-shadow: var(--nn-shadow-lg);
	max-height: 320px;
	overflow: auto;
}
.nn-recipes-suggest__item {
	display: flex;
	align-items: center;
	gap: .55rem;
	padding: .6rem .7rem;
	border-radius: .65rem;
	cursor: pointer;
	font-size: .95rem;
	color: var(--nn-ink);
}
.nn-recipes-suggest__item:hover,
.nn-recipes-suggest__item.is-active {
	background: var(--nn-emerald-soft);
}
.nn-recipes-suggest__tag {
	margin-left: auto;
	font-size: .72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: var(--nn-emerald-dark);
	background: var(--nn-emerald-soft);
	padding: .12rem .5rem;
	border-radius: 999px;
}

/* Filters */
.nn-recipes-filters {
	display: flex;
	flex-direction: column;
	gap: .8rem;
	background: var(--nn-soft);
	border: 1px solid var(--nn-border);
	border-radius: var(--nn-r-lg);
	padding: 1rem 1.1rem;
	margin-bottom: 1.4rem;
}
.nn-recipes-fgroup {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .45rem .6rem;
}
.nn-recipes-fgroup__label {
	font-size: .76rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--nn-muted);
	min-width: 6.5rem;
}
.nn-recipes-fgroup__chips {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
}
.nn-chip {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	border: 1.5px solid var(--nn-border);
	background: #fff;
	color: var(--nn-ink);
	border-radius: var(--nn-r-pill);
	padding: .35rem .8rem;
	font-size: .85rem;
	font-weight: 600;
	cursor: pointer;
	transition: all .14s ease;
	line-height: 1.2;
}
.nn-chip:hover {
	border-color: var(--nn-emerald);
	color: var(--nn-emerald-dark);
}
.nn-chip.is-active {
	background: var(--nn-emerald);
	border-color: var(--nn-emerald);
	color: #fff;
}
.nn-chip__n {
	font-size: .72rem;
	font-weight: 700;
	opacity: .7;
}
.nn-chip.is-active .nn-chip__n {
	opacity: .85;
}
.nn-recipes-reset {
	align-self: flex-start;
	border: 0;
	background: transparent;
	color: var(--nn-emerald-dark);
	font-weight: 700;
	font-size: .85rem;
	cursor: pointer;
	padding: .2rem .1rem;
	text-decoration: underline;
}
.nn-recipes-count {
	color: var(--nn-muted);
	font-size: .9rem;
	margin: 0 0 1rem;
	min-height: 1.2em;
}

/* Grid */
.nn-recipes__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.1rem;
}
.nn-recipes__grid.is-loading {
	opacity: .5;
	pointer-events: none;
}
.nn-recipes__empty {
	grid-column: 1 / -1;
	text-align: center;
	color: var(--nn-muted);
	padding: 2.5rem 1rem;
}
@media (min-width: 600px) {
	.nn-recipes__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 940px) {
	.nn-recipes__grid { grid-template-columns: repeat(3, 1fr); }
}

/* Recipe card */
.nn-rcard {
	background: #fff;
	border: 1px solid var(--nn-border);
	border-radius: var(--nn-r-lg);
	overflow: hidden;
	box-shadow: var(--nn-shadow-sm);
	transition: transform .16s ease, box-shadow .16s ease;
}
.nn-rcard:hover {
	transform: translateY(-3px);
	box-shadow: var(--nn-shadow-lg);
}
.nn-rcard__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
}
.nn-rcard__media {
	position: relative;
	aspect-ratio: 4 / 3;
	background: var(--nn-emerald-soft);
	overflow: hidden;
}
.nn-rcard__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.nn-rcard__media--ph {
	display: grid;
	place-items: center;
}
.nn-rcard__media--ph svg {
	width: 38%;
	height: 38%;
	opacity: .6;
}
.nn-rcard__badge {
	position: absolute;
	top: .7rem;
	left: .7rem;
	background: rgba(255, 255, 255, .94);
	color: var(--nn-emerald-dark);
	font-size: .72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .04em;
	padding: .25rem .6rem;
	border-radius: 999px;
	box-shadow: var(--nn-shadow-sm);
}
.nn-rcard__body {
	display: flex;
	flex-direction: column;
	gap: .4rem;
	padding: .95rem 1rem 1.1rem;
	flex: 1;
}
.nn-rcard__title {
	font-size: 1.08rem;
	font-weight: 700;
	line-height: 1.25;
	color: var(--nn-ink);
}
.nn-rcard__excerpt {
	font-size: .88rem;
	color: var(--nn-muted);
	line-height: 1.5;
	flex: 1;
}
.nn-rcard__meta {
	display: flex;
	flex-wrap: wrap;
	gap: .35rem .9rem;
	margin-top: .35rem;
	padding-top: .7rem;
	border-top: 1px solid var(--nn-border);
}
.nn-rcard__m {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	font-size: .8rem;
	font-weight: 600;
	color: var(--nn-muted);
}
.nn-rcard__m .nn-ricon {
	width: 1rem;
	height: 1rem;
	color: var(--nn-emerald);
}

.nn-recipes-more {
	display: block;
	margin: 1.6rem auto 0;
	padding: .8rem 1.6rem;
	border: 1.5px solid var(--nn-emerald);
	background: #fff;
	color: var(--nn-emerald-dark);
	font-weight: 700;
	border-radius: var(--nn-r-pill);
	cursor: pointer;
}
.nn-recipes-more:hover {
	background: var(--nn-emerald);
	color: #fff;
}
.nn-recipes-more[hidden] {
	display: none;
}
.nn-recipes-app.is-js .nn-recipes-ssr-pager {
	display: none;
}

/* ---------- Single recipe ---------- */
.nn-recipe__hero img {
	border-radius: var(--nn-r-lg);
}
.nn-recipe__tags {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
	margin-top: .7rem;
}
.nn-recipe__tag {
	font-size: .8rem;
	font-weight: 600;
	color: var(--nn-emerald-dark);
	background: var(--nn-emerald-soft);
	padding: .25rem .7rem;
	border-radius: 999px;
	text-decoration: none;
}
.nn-recipe__tag:hover {
	background: var(--nn-emerald);
	color: #fff;
}

/* Meta card */
.nn-rmeta {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: .5rem;
	background: var(--nn-soft);
	border: 1px solid var(--nn-border);
	border-radius: var(--nn-r-lg);
	padding: 1rem;
	margin: 1.4rem 0;
}
.nn-rmeta__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: .15rem;
	padding: .4rem .2rem;
}
.nn-rmeta__v {
	font-size: 1.15rem;
	font-weight: 800;
	color: var(--nn-emerald-dark);
}
.nn-rmeta__l {
	font-size: .72rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--nn-muted);
	font-weight: 600;
}
@media (min-width: 600px) {
	.nn-rmeta { grid-template-columns: repeat(5, 1fr); }
}
.nn-rnutri {
	background: #fff;
	border: 1px dashed var(--nn-border);
	border-radius: var(--nn-r-md);
	padding: .85rem 1rem;
	margin: 0 0 1.6rem;
}
.nn-rnutri__l {
	display: block;
	font-size: .74rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--nn-muted);
	font-weight: 700;
	margin-bottom: .5rem;
}
.nn-rnutri__row {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem 1.4rem;
}
.nn-rnutri__c {
	font-size: .9rem;
	color: var(--nn-muted);
}
.nn-rnutri__c b {
	color: var(--nn-ink);
}

/* Section headings */
.nn-recipe__content .nn-recipe__h {
	font-size: 1.5rem;
	margin: 2rem 0 1rem;
	color: var(--nn-ink);
	display: flex;
	align-items: baseline;
	gap: .6rem;
}
.nn-recipe__h-note {
	font-size: .85rem;
	font-weight: 600;
	color: var(--nn-muted);
}

/* Ingredients */
.nn-ingredients {
	list-style: none;
	margin: 0 0 1rem;
	padding: 0;
	display: grid;
	gap: .1rem;
}
.nn-ingredients__item {
	display: flex;
	align-items: baseline;
	gap: .8rem;
	padding: .6rem .2rem;
	border-bottom: 1px solid var(--nn-border);
}
.nn-ingredients__item:last-child {
	border-bottom: 0;
}
.nn-ingredients__qty {
	flex: none;
	min-width: 5.5rem;
	font-weight: 800;
	color: var(--nn-emerald-dark);
	font-variant-numeric: tabular-nums;
}
.nn-ingredients__name {
	color: var(--nn-ink);
}

/* Steps */
.nn-steps {
	list-style: none;
	counter-reset: none;
	margin: 0 0 1rem;
	padding: 0;
}
.nn-step {
	display: grid;
	grid-template-columns: 3rem 1fr;
	gap: .4rem 1rem;
	align-items: start;
	padding: 1.4rem 0;
	border-top: 1px solid var(--nn-border);
}
.nn-step:first-child {
	border-top: 0;
	padding-top: .4rem;
}
.nn-step__badge {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: 999px;
	background: var(--nn-emerald);
	color: #fff;
	font-size: 1.3rem;
	font-weight: 800;
	box-shadow: 0 4px 10px rgba(5, 150, 105, .35);
	flex: none;
}
.nn-step__body {
	font-size: 1.06rem;
	line-height: 1.65;
}
.nn-step__body p {
	margin: 0;
}
.nn-step__tip {
	margin-top: .55rem !important;
	font-size: .92rem;
	color: var(--nn-emerald-dark);
	background: var(--nn-emerald-soft);
	border-radius: var(--nn-r-md);
	padding: .55rem .8rem;
	line-height: 1.5;
}
.nn-step__tip-k {
	font-weight: 800;
	text-transform: uppercase;
	font-size: .72rem;
	letter-spacing: .04em;
	margin-right: .35rem;
}
/* Image steps stack the illustration with the number badge overlaid */
.nn-step--img {
	grid-template-columns: 1fr;
}
.nn-step__media {
	position: relative;
	border-radius: var(--nn-r-lg);
	overflow: hidden;
	margin: 0 0 .9rem;
	background: var(--nn-emerald-soft);
	aspect-ratio: 3 / 2;
}
.nn-step__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.nn-step--img .nn-step__media .nn-step__badge {
	position: absolute;
	top: .85rem;
	left: .85rem;
	width: 2.8rem;
	height: 2.8rem;
	font-size: 1.25rem;
	border: 3px solid #fff;
	box-shadow: 0 4px 14px rgba(0, 0, 0, .25);
}

/* Benefits */
.nn-recipe-benefits {
	background: var(--nn-soft);
	border-radius: var(--nn-r-lg);
	padding: 1.1rem 1.3rem 1.3rem;
	margin: 1.8rem 0;
}
.nn-recipe-benefits .nn-recipe__h {
	margin-top: .3rem;
}
.nn-benefits {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: .6rem;
}
.nn-benefits__item {
	position: relative;
	padding-left: 1.9rem;
	line-height: 1.55;
	color: var(--nn-ink);
}
.nn-benefits__item::before {
	content: "";
	position: absolute;
	left: 0;
	top: .15rem;
	width: 1.25rem;
	height: 1.25rem;
	background: var(--nn-emerald);
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 6 9 17l-5-5' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 6 9 17l-5-5' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Callouts (tips / curiosity / warning) */
.nn-recipe__content .nn-callout {
	border: 1px solid var(--nn-border);
	border-left: 4px solid var(--nn-emerald);
	background: #fff;
	border-radius: var(--nn-r-md);
	padding: 1rem 1.2rem;
	margin: 1.4rem 0;
}
.nn-recipe__content .nn-callout__title {
	font-weight: 800;
	margin: 0 0 .4rem;
	color: var(--nn-emerald-dark);
}
.nn-recipe__content .nn-callout ul {
	margin: 0;
	padding-left: 1.1rem;
}
.nn-recipe__content .nn-callout p:last-child {
	margin-bottom: 0;
}
.nn-callout--sapevi-che {
	border-left-color: #2563eb;
	background: #eff6ff;
}
.nn-callout--sapevi-che .nn-callout__title {
	color: #1d4ed8;
}
.nn-recipe-warning {
	border-left-color: #d97706 !important;
	background: #fffbeb !important;
}
.nn-recipe-warning .nn-callout__title {
	color: #b45309 !important;
}

.nn-ricon {
	display: inline-block;
	vertical-align: middle;
}

/* ---------- TL;DR / FAQ / Sources (AEO/GEO) ---------- */
.nn-recipe-tldr {
	margin-top: 0;
}
.nn-recipe-tldr p:last-child {
	margin: 0;
	font-size: 1.05rem;
	line-height: 1.6;
	color: var(--nn-ink);
}
.nn-recipe-faq {
	margin: 2rem 0 0;
}
.nn-recipe-faq .nn-faq__q {
	font-size: 1.08rem;
	margin: 1.1rem 0 .3rem;
	color: var(--nn-ink);
}
.nn-recipe-faq .nn-faq__a {
	margin: 0 0 .6rem;
	color: var(--nn-muted);
	line-height: 1.6;
}
.nn-recipe-sources {
	margin: 1.8rem 0 0;
	padding: .9rem 1.1rem;
	background: var(--nn-soft);
	border: 1px dashed var(--nn-border);
	border-radius: var(--nn-r-md);
}
.nn-recipe-sources__k {
	margin: 0 0 .4rem;
	font-size: .74rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--nn-muted);
}
.nn-recipe-sources ul {
	margin: 0;
	padding-left: 1.1rem;
}
.nn-recipe-sources a {
	color: var(--nn-emerald-dark);
	word-break: break-word;
}
