/* ========================================================================
   RecipeRide — Main stylesheet
   Reset → tokens → layout → nav/footer → cards → recipe ride (7 acts)
   ======================================================================== */

/* -- Tokens (overridden by per-cuisine theme packs on .rr-ride) ------------ */
:root {
	--rr-color-paper:   #FAF6EC;
	--rr-color-ink:     #1F1B16;
	--rr-color-accent:  #C9302C;
	--rr-color-accent2: #E8A0A8;
	--rr-color-leaf:    #6E8C5E;
	--rr-color-sun:     #F5C04A;
	--rr-color-deep:    #2A1E1B;
	--rr-color-paper-dark: #f1ead8;
	--rr-color-muted:   #6b6358;

	--rr-font-display: "Playfair Display", Georgia, serif;
	--rr-font-accent:  "Caveat", "Comic Sans MS", cursive;
	--rr-font-body:    "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;

	--rr-radius:    14px;
	--rr-radius-sm: 8px;
	--rr-shadow-1:  0 1px 2px rgba(31,27,22,.06), 0 8px 24px rgba(31,27,22,.08);
	--rr-shadow-2:  0 4px 12px rgba(31,27,22,.10), 0 24px 48px rgba(31,27,22,.10);

	--rr-max-w: 1200px;
	--rr-pad:   clamp(16px, 4vw, 40px);
}

/* -- Reset --------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--rr-font-body);
	color: var(--rr-color-ink);
	background: var(--rr-color-paper);
	background-image:
		radial-gradient(rgba(31,27,22,.025) 1px, transparent 1px),
		radial-gradient(rgba(31,27,22,.02)  1px, transparent 1px);
	background-size: 24px 24px, 48px 48px;
	background-position: 0 0, 12px 12px;
	font-size: 17px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
img, video { max-width: 100%; height: auto; display: block; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
a { color: var(--rr-color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 { font-family: var(--rr-font-display); line-height: 1.15; margin: 0 0 .4em; }
h1 { font-size: clamp(2rem, 1.4rem + 3vw, 3.8rem); }
h2 { font-size: clamp(1.6rem, 1.2rem + 2vw, 2.6rem); }
h3 { font-size: clamp(1.25rem, 1rem + 1vw, 1.6rem); }
p  { margin: 0 0 1em; }

/* Reduced motion ----------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
	html { scroll-behavior: auto; }
}

/* -- Common utility ------------------------------------------------------ */
.rr-skip { position:absolute; left:-1000px; top:-1000px; }
.rr-skip:focus { left:8px; top:8px; background: var(--rr-color-ink); color: var(--rr-color-paper); padding:8px 12px; border-radius: 6px; z-index: 1000; }

.rr-eyebrow {
	font-family: var(--rr-font-body);
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	font-size: 12px;
	color: var(--rr-color-accent);
}

.rr-btn {
	display: inline-flex; align-items: center; justify-content: center;
	gap: .5rem;
	padding: 12px 22px;
	border-radius: 999px;
	font-weight: 600;
	text-decoration: none;
	transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
	border: 2px solid transparent;
}
.rr-btn:hover { transform: translateY(-1px); text-decoration: none; }
.rr-btn--accent { background: var(--rr-color-accent); color: #fff; box-shadow: var(--rr-shadow-1); }
.rr-btn--accent:hover { background: var(--rr-color-deep); }
.rr-btn--ghost  { background: transparent; color: var(--rr-color-ink); border-color: var(--rr-color-ink); }
.rr-btn--lg     { padding: 14px 28px; font-size: 1.05rem; }
.rr-btn small   { opacity: .8; font-weight: 400; }

/* -- Nav ------------------------------------------------------------------ */
.rr-nav {
	position: sticky; top: 0; z-index: 50;
	background: rgba(250,246,236,.92);
	backdrop-filter: saturate(140%) blur(8px);
	-webkit-backdrop-filter: saturate(140%) blur(8px);
	border-bottom: 1px solid rgba(31,27,22,.06);
}
.rr-nav__inner {
	max-width: var(--rr-max-w);
	margin: 0 auto;
	display: flex; align-items: center; gap: 24px;
	padding: 12px var(--rr-pad);
}
.rr-nav__brand { display: flex; align-items: center; gap: 10px; color: var(--rr-color-ink); font-family: var(--rr-font-display); font-weight: 700; font-size: 1.1rem; }
.rr-nav__brand:hover { text-decoration: none; }
.rr-nav__logo { font-size: 1.5rem; }
.rr-nav__menu { flex: 1; }
.rr-nav__menu ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; flex-wrap: wrap; }
.rr-nav__menu a { color: var(--rr-color-ink); font-weight: 500; opacity: .8; }
.rr-nav__menu a:hover { opacity: 1; text-decoration: none; }
.rr-passport-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 8px 14px; border-radius: 999px;
	background: var(--rr-color-paper-dark); color: var(--rr-color-ink);
	font-weight: 600;
}
.rr-passport-btn__level { background: var(--rr-color-accent); color: #fff; border-radius: 999px; padding: 1px 8px; font-size: 12px; }

@media (max-width: 720px) {
	.rr-nav__menu { display: none; }
}

/* -- Footer --------------------------------------------------------------- */
.rr-footer { background: var(--rr-color-deep); color: #f8efe0; padding: 60px 0 24px; margin-top: 80px; }
.rr-footer__inner {
	max-width: var(--rr-max-w); margin: 0 auto; padding: 0 var(--rr-pad);
	display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 32px;
}
.rr-footer__brand { display: flex; align-items: center; gap: 10px; font-family: var(--rr-font-display); font-weight: 700; font-size: 1.2rem; margin-bottom: 6px; }
.rr-footer h4 { color: var(--rr-color-accent2); margin-bottom: 12px; }
.rr-footer ul { list-style: none; padding: 0; margin: 0; }
.rr-footer li { margin-bottom: 6px; }
.rr-footer a { color: #f8efe0; opacity: .85; }
.rr-footer a:hover { opacity: 1; text-decoration: underline; }
.rr-newsletter { display: flex; gap: 8px; margin-top: 8px; }
.rr-newsletter input {
	flex: 1; padding: 10px 14px; border-radius: 999px;
	background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
	color: #fff;
}
.rr-newsletter button { padding: 10px 18px; border-radius: 999px; background: var(--rr-color-accent); color: #fff; font-weight: 600; }
.rr-footer__legal { max-width: var(--rr-max-w); margin: 32px auto 0; padding: 16px var(--rr-pad) 0; border-top: 1px solid rgba(255,255,255,.08); color: #d4c8b3; }
@media (max-width: 800px) { .rr-footer__inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .rr-footer__inner { grid-template-columns: 1fr; } }

/* -- Cards grid ----------------------------------------------------------- */
.rr-archive { max-width: var(--rr-max-w); margin: 40px auto; padding: 0 var(--rr-pad); }
.rr-archive__head { margin-bottom: 24px; }
.rr-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 28px; }
.rr-card {
	display: flex; flex-direction: column;
	background: #fff;
	border-radius: var(--rr-radius);
	overflow: hidden;
	box-shadow: var(--rr-shadow-1);
	color: var(--rr-color-ink);
	transition: transform .2s ease, box-shadow .2s ease;
}
.rr-card:hover { transform: translateY(-3px); box-shadow: var(--rr-shadow-2); text-decoration: none; }
.rr-card__media { position: relative; aspect-ratio: 4 / 3; background: var(--rr-color-paper-dark); }
.rr-card__media img { width: 100%; height: 100%; object-fit: cover; }
.rr-card__cuisine {
	position: absolute; left: 12px; top: 12px;
	background: var(--rr-color-accent); color: #fff;
	padding: 4px 12px; border-radius: 999px;
	font-size: 11px; letter-spacing: .1em; text-transform: uppercase; font-weight: 700;
}
.rr-card__body { padding: 18px 18px 22px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.rr-card__title { margin: 0; font-size: 1.3rem; }
.rr-card__excerpt { color: var(--rr-color-muted); flex: 1; }
.rr-card__meta { display: flex; gap: 12px; color: var(--rr-color-muted); font-size: 14px; }

/* -- Homepage ------------------------------------------------------------- */
.rr-home-hero {
	max-width: var(--rr-max-w); margin: 40px auto; padding: 0 var(--rr-pad);
	display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center;
}
.rr-home-hero__kicker { display: block; margin-bottom: 8px; }
.rr-home-hero__copy h1 { font-size: clamp(2.4rem, 1.6rem + 4vw, 4.5rem); }
.rr-home-hero__copy h1 a { color: inherit; }
.rr-home-hero__copy h1 a:hover { color: var(--rr-color-accent); text-decoration: none; }
.rr-home-hero__meta { display: flex; gap: 14px; color: var(--rr-color-muted); margin-bottom: 24px; }
.rr-home-hero__media { position: relative; }
.rr-home-hero__img { border-radius: var(--rr-radius); box-shadow: var(--rr-shadow-2); aspect-ratio: 4/3; object-fit: cover; }
.rr-home-hero__media .rr-doodle { position: absolute; right: -10px; top: -20px; color: var(--rr-color-accent); width: 56px; transform: rotate(15deg); }

.rr-home-rail { max-width: var(--rr-max-w); margin: 60px auto; padding: 0 var(--rr-pad); }
.rr-home-rail h2 { margin-bottom: 18px; }
.rr-rail { display: flex; gap: 14px; overflow-x: auto; padding-bottom: 8px; scroll-snap-type: x mandatory; }
.rr-rail::-webkit-scrollbar { height: 6px; }
.rr-rail::-webkit-scrollbar-thumb { background: rgba(31,27,22,.2); border-radius: 999px; }
.rr-rail__chip {
	flex: 0 0 auto;
	background: var(--chip-bg, var(--rr-color-accent));
	color: #fff; padding: 14px 22px; border-radius: var(--rr-radius);
	scroll-snap-align: start;
	display: flex; flex-direction: column; gap: 4px; min-width: 140px;
	box-shadow: var(--rr-shadow-1);
}
.rr-rail__chip:hover { transform: translateY(-2px); text-decoration: none; }
.rr-rail__chip-label { font-family: var(--rr-font-display); font-weight: 700; font-size: 1.15rem; }
.rr-rail__chip small { opacity: .85; }

.rr-home-grid { max-width: var(--rr-max-w); margin: 60px auto; padding: 0 var(--rr-pad); }
.rr-home-grid h2 { margin-bottom: 18px; }

@media (max-width: 800px) { .rr-home-hero { grid-template-columns: 1fr; } }

/* -- Ad placeholders ------------------------------------------------------ */
.rr-ad {
	display: block;
	max-width: 900px;
	margin: 32px auto;
	background: var(--rr-color-paper-dark);
	border: 1px dashed rgba(31,27,22,.2);
	border-radius: var(--rr-radius);
	display: flex; align-items: center; justify-content: center;
	color: var(--rr-color-muted); font-size: 13px;
	min-height: 90px;
}
.rr-ad--placeholder span { padding: 8px 16px; }
.rr-sticky-ad {
	position: fixed; left: 0; right: 0; bottom: 0; z-index: 40;
	display: flex; align-items: center; justify-content: center;
	padding: 8px 8px 12px;
	background: linear-gradient(to top, rgba(250,246,236,.98), rgba(250,246,236,.7));
}
.rr-sticky-ad .rr-ad { margin: 0; max-height: 90px; min-height: 60px; }
.rr-sticky-ad__close {
	position: absolute; right: 12px; top: 4px;
	width: 28px; height: 28px; border-radius: 50%;
	background: var(--rr-color-ink); color: var(--rr-color-paper);
	font-size: 18px;
}
.rr-sticky-ad[data-closed] { display: none; }

/* ============== RECIPE RIDE — single page ============================== */

.rr-ride { background: var(--rr-color-paper); }
.rr-recipe { position: relative; }

/* Progress bar */
.rr-progress {
	position: sticky; top: 60px; z-index: 30;
	height: 3px; background: rgba(31,27,22,.06);
}
.rr-progress__bar { height: 100%; width: 0; background: var(--rr-color-accent); transition: width .15s linear; }

/* -- Act shared ----------------------------------------------------------- */
.rr-act {
	position: relative;
	max-width: var(--rr-max-w);
	margin: 0 auto;
	padding: 80px var(--rr-pad);
}
.rr-doodle { color: var(--rr-color-accent); width: 48px; display: inline-block; }

/* -- Act 1 — Cold Open --------------------------------------------------- */
.rr-act-1 {
	min-height: 90vh;
	display: grid; place-items: center;
	max-width: none;
	padding: 0;
	overflow: hidden;
	isolation: isolate;
}
.rr-act-1__layer { position: absolute; inset: 0; }
.rr-act-1__layer--paper {
	background:
		radial-gradient(ellipse at 30% 30%, var(--rr-color-accent2) 0%, transparent 55%),
		radial-gradient(ellipse at 70% 70%, var(--rr-color-sun) 0%, transparent 55%),
		var(--rr-color-paper);
	opacity: .6;
}
.rr-act-1__layer--motif { pointer-events: none; }
.rr-motif { position: absolute; color: var(--rr-color-deep); opacity: .14; pointer-events: none; }
.rr-motif--hangul { font-family: var(--rr-font-display); font-size: clamp(80px, 22vw, 320px); font-weight: 700; letter-spacing: -.05em; }
.rr-motif--hangul[data-rr-i="0"] { left: 4vw; top: 8vh; }
.rr-motif--icon { width: 120px; height: 120px; right: 8vw; bottom: 12vh; background: currentColor; -webkit-mask: radial-gradient(circle, currentColor 60%, transparent 61%); mask: radial-gradient(circle, currentColor 60%, transparent 61%); }

.rr-act-1__content {
	position: relative; z-index: 2;
	text-align: center;
	max-width: 760px;
	padding: 0 var(--rr-pad);
}
.rr-act-1__greeting { font-family: var(--rr-font-accent); font-size: clamp(1.5rem, 1rem + 2vw, 2.5rem); color: var(--rr-color-accent); margin-bottom: 1.4em; }
.rr-act-1__cold-open { font-family: var(--rr-font-display); font-size: clamp(1.6rem, 1rem + 2vw, 2.4rem); font-style: italic; line-height: 1.3; color: var(--rr-color-deep); }
.rr-act-1__line { font-family: var(--rr-font-display); font-size: clamp(1.6rem, 1rem + 2vw, 2.4rem); font-style: italic; line-height: 1.3; margin: 8px 0; opacity: 0; transform: translateY(20px); }
.rr-act-1.is-revealed .rr-act-1__line { opacity: 1; transform: none; transition: opacity .6s ease, transform .6s ease; }
.rr-act-1.is-revealed .rr-act-1__line:nth-child(2) { transition-delay: .15s; }
.rr-act-1.is-revealed .rr-act-1__line:nth-child(3) { transition-delay: .30s; }
.rr-act-1.is-revealed .rr-act-1__line:nth-child(4) { transition-delay: .45s; }
.rr-act-1__scroll { display: inline-block; margin-top: 40px; font-family: var(--rr-font-accent); font-size: 1.3rem; color: var(--rr-color-muted); animation: rr-bob 2.4s ease-in-out infinite; }
@keyframes rr-bob { 50% { transform: translateY(8px); } }

/* -- Act 2 — Hero --------------------------------------------------------- */
.rr-act-2 {
	display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center;
	padding-top: 40px; padding-bottom: 100px;
}
.rr-act-2__media { position: relative; }
.rr-act-2__photo {
	border-radius: var(--rr-radius);
	box-shadow: var(--rr-shadow-2);
	aspect-ratio: 4/5; object-fit: cover; width: 100%;
}
.rr-doodle--heart { position: absolute; right: -14px; top: -18px; width: 64px; color: var(--rr-color-accent); transform: rotate(15deg); }
.rr-act-2__kicker { font-family: var(--rr-font-body); font-weight: 800; font-size: 14px; letter-spacing: .2em; color: var(--rr-color-accent); }
.rr-act-2__title { font-size: clamp(2.4rem, 1.5rem + 4vw, 4.4rem); margin: 12px 0 14px; }
.rr-act-2__tagline { font-family: var(--rr-font-accent); font-size: 1.6rem; line-height: 1.3; color: var(--rr-color-deep); margin-bottom: 22px; }
.rr-act-2__stats {
	list-style: none; padding: 0; margin: 0 0 24px;
	display: flex; flex-wrap: wrap; gap: 18px;
	font-weight: 600; color: var(--rr-color-ink);
}
.rr-act-2__stats li { background: var(--rr-color-paper-dark); padding: 8px 14px; border-radius: 999px; }
.rr-act-2__cta { display: flex; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.rr-act-2__social-proof { color: var(--rr-color-muted); font-size: 14px; }
.rr-spice { display: inline-flex; gap: 2px; }
.rr-spice__pepper { filter: grayscale(1); opacity: .35; }
.rr-spice__pepper.is-active { filter: none; opacity: 1; }
.rr-difficulty { display: inline-flex; align-items: center; gap: 6px; }
.rr-difficulty__dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(31,27,22,.2); }
.rr-difficulty__dot.is-active { background: var(--rr-color-accent); }
.rr-difficulty__label { margin-left: 6px; }
@media (max-width: 800px) {
	.rr-act-2 { grid-template-columns: 1fr; gap: 32px; }
}

/* -- Act 3 — Story -------------------------------------------------------- */
.rr-act-3__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; }
.rr-act-3__story p { font-size: 1.08rem; }
.rr-cpc-callout {
	margin-top: 24px;
	background: linear-gradient(135deg, var(--rr-color-sun) 0%, #FFE9A8 100%);
	border-radius: var(--rr-radius);
	padding: 22px 24px;
	box-shadow: var(--rr-shadow-1);
}
.rr-cpc-callout strong { display: block; margin-bottom: 6px; font-size: 1.1rem; }
.rr-cpc-callout .rr-btn { margin-top: 10px; }

.rr-act-3__sidebar { display: grid; gap: 20px; align-content: start; }
/* Sticky-note clippings — uneven paper, dog-ear corners, light shadow */
.rr-sticky-note {
	position: relative;
	background: var(--rr-color-sun);
	padding: 18px 22px 22px;
	border-radius: 0;
	box-shadow:
		1px 1px 0 rgba(31,27,22,.05),
		3px 4px 0 rgba(31,27,22,.05),
		6px 8px 16px -8px rgba(31,27,22,.20);
	font-family: var(--rr-font-accent);
	transform: rotate(-1.4deg);
	transition: transform .2s ease;
	clip-path:
		polygon(
			0% 4%, 2% 0%, 50% 1%, 98% 0%, 100% 6%,
			99% 50%, 100% 96%, 96% 100%,
			50% 99%, 4% 100%, 0% 95%, 1% 50%
		);
}
.rr-sticky-note:nth-child(even) { transform: rotate(1.6deg); }
.rr-sticky-note:hover { transform: rotate(0); }
.rr-sticky-note::after {
	/* dog-ear corner fold */
	content: '';
	position: absolute; right: 0; bottom: 0;
	width: 22px; height: 22px;
	background:
		linear-gradient(225deg, rgba(31,27,22,.18) 0%, rgba(31,27,22,.05) 40%, transparent 50%),
		linear-gradient(225deg, transparent 50%, rgba(0,0,0,.12) 60%);
}
.rr-sticky-note strong {
	display: block;
	font-family: var(--rr-font-body);
	font-size: 11px;
	letter-spacing: .18em;
	margin-bottom: 6px;
	color: var(--rr-color-deep);
	font-weight: 800;
}
.rr-sticky-note p   { font-size: 1.18rem; line-height: 1.4; margin: 0; }
.rr-sticky-note ul  { margin: 0; padding-left: 1.1em; font-size: 1.12rem; }
.rr-sticky-note--yellow { background: #FFEAA0; }
.rr-sticky-note--pink   { background: #F8C4CC; }
.rr-sticky-note--green  { background: #C8DEAA; }
.rr-sticky-note--blue   { background: #C2D8EC; }
.rr-sticky-note--inline { margin: 16px 0; transform: rotate(-.8deg); }
@media (max-width: 800px) { .rr-act-3__grid { grid-template-columns: 1fr; } }

/* -- Ingredients ---------------------------------------------------------- */
.rr-act-ing__head { text-align: center; margin-bottom: 28px; }
.rr-act-ing__hint { font-family: var(--rr-font-accent); font-size: 1.25rem; color: var(--rr-color-muted); }
.rr-ing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 28px; }
.rr-ing-group__title {
	font-family: var(--rr-font-display);
	background: var(--rr-color-accent);
	color: #fff;
	display: inline-block;
	padding: 6px 16px;
	border-radius: 6px;
	margin-bottom: 12px;
	transform: rotate(-1deg);
}
.rr-ing-group__list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.rr-ing-card {
	position: relative;
	background: #fff;
	border-radius: var(--rr-radius-sm);
	padding: 14px 16px;
	box-shadow: var(--rr-shadow-1);
	display: flex; gap: 10px; align-items: baseline;
	transform-style: preserve-3d;
	transition: transform .2s ease, box-shadow .2s ease;
	cursor: default;
}
.rr-ing-card[data-rr-tilt]:hover { box-shadow: var(--rr-shadow-2); }
.rr-ing-card__qty { font-family: var(--rr-font-display); font-weight: 700; color: var(--rr-color-accent); min-width: 80px; }
.rr-ing-card__name { color: var(--rr-color-ink); }
.rr-ing-card__back { display: none; }
[data-rr-shopping-list] { margin: 32px auto 0; display: block; }

/* -- Cook (Act 4) — pinned scrollytell ----------------------------------- */
.rr-act-cook { padding-bottom: 0; }
.rr-act-cook__head { text-align: center; margin-bottom: 30px; }
.rr-cook-track { display: grid; gap: 100px; padding: 40px 0 120px; }
.rr-cook-step {
	display: grid; grid-template-columns: 120px 1fr 1fr; gap: 28px;
	align-items: center;
	opacity: 0; transform: translateY(40px);
	transition: opacity .6s ease, transform .6s ease;
}
.rr-cook-step.is-active { opacity: 1; transform: none; }
.rr-cook-step__num {
	width: 90px; height: 90px; border-radius: 50%;
	background: var(--rr-color-accent); color: #fff;
	display: grid; place-items: center;
	font-family: var(--rr-font-display); font-size: 2.4rem; font-weight: 700;
	box-shadow: var(--rr-shadow-2);
}
.rr-cook-step__placeholder {
	aspect-ratio: 1; background: var(--rr-color-paper-dark); border-radius: var(--rr-radius);
	display: grid; place-items: center; font-size: 4rem; opacity: .6;
	box-shadow: var(--rr-shadow-1);
}
.rr-cook-step__title { margin-bottom: 8px; }
.rr-cook-step__body { font-size: 1.08rem; color: var(--rr-color-ink); }
.rr-timer {
	margin-top: 14px;
	display: inline-flex; align-items: center; gap: 8px;
	padding: 10px 18px; border-radius: 999px;
	background: var(--rr-color-paper-dark); color: var(--rr-color-ink); font-weight: 600;
}
.rr-timer.is-running { background: var(--rr-color-accent); color: #fff; }
@media (max-width: 800px) {
	.rr-cook-step { grid-template-columns: 70px 1fr; }
	.rr-cook-step__media { grid-column: 1 / -1; order: 2; }
	.rr-cook-step__copy { grid-column: 1 / -1; order: 3; }
	.rr-cook-step__num { width: 64px; height: 64px; font-size: 1.6rem; }
}

/* Polaroid */
.rr-polaroid {
	background: #fff;
	padding: 10px 10px 50px;
	box-shadow: var(--rr-shadow-2);
	transition: transform .2s ease;
}
.rr-polaroid:hover { transform: rotate(0) scale(1.02) !important; }
.rr-polaroid img { aspect-ratio: 1; object-fit: cover; }
.rr-polaroid figcaption { position: relative; margin-top: 8px; font-family: var(--rr-font-accent); font-size: 1.15rem; text-align: center; color: var(--rr-color-deep); }

/* -- Act 5 — Reveal ------------------------------------------------------- */
.rr-act-reveal { text-align: center; padding-top: 60px; padding-bottom: 80px; position: relative; overflow: hidden; }
.rr-act-reveal__inner { max-width: 720px; margin: 0 auto; position: relative; z-index: 2; }
.rr-act-reveal__photo {
	border-radius: 50%;
	width: 280px; height: 280px;
	object-fit: cover;
	margin: 0 auto 28px;
	box-shadow: 0 0 0 8px #fff, var(--rr-shadow-2);
	transform: scale(.6); opacity: 0;
	transition: transform .8s cubic-bezier(.22,.61,.36,1), opacity .8s ease;
}
.rr-act-reveal.is-revealed .rr-act-reveal__photo { transform: none; opacity: 1; }
.rr-act-reveal__title { font-size: clamp(2rem, 1.4rem + 3vw, 3.4rem); }
.rr-act-reveal__line { font-family: var(--rr-font-accent); font-size: 1.5rem; }
.rr-act-reveal__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 18px; }
.rr-act-reveal__confetti { position: absolute; inset: 0; pointer-events: none; z-index: 1; }

/* -- Act 6 — Secret Tip --------------------------------------------------- */
.rr-act-secret { text-align: center; }
.rr-act-secret__envelope {
	max-width: 720px; margin: 0 auto;
	background: linear-gradient(135deg, #FFF7E0 0%, #FAE2B6 100%);
	border-radius: var(--rr-radius);
	padding: 60px 28px 50px;
	box-shadow: var(--rr-shadow-2);
	position: relative;
	overflow: hidden;
}
.rr-act-secret__envelope::before {
	content: ''; position: absolute; inset: 0;
	background: repeating-linear-gradient(45deg, transparent 0 18px, rgba(201,48,44,.06) 18px 20px);
	pointer-events: none;
}
.rr-act-secret__stamp {
	position: absolute; right: 24px; top: 24px;
	border: 2.5px solid var(--rr-color-accent); color: var(--rr-color-accent);
	font-family: var(--rr-font-display); font-weight: 700; letter-spacing: .14em;
	padding: 8px 14px; border-radius: 6px;
	transform: rotate(-10deg);
	font-size: 11px; text-align: center; line-height: 1.2;
}
.rr-act-secret__envelope[data-locked="0"] .rr-act-secret__seal,
.rr-act-secret__envelope:not([data-locked]) .rr-act-secret__seal {
	display: none;
}
.rr-act-secret__envelope[data-locked="0"] .rr-act-secret__content,
.rr-act-secret__envelope:not([data-locked]) .rr-act-secret__content {
	display: block !important;
}
.rr-act-secret__envelope[data-unlocked="1"] .rr-act-secret__seal { display: none; }
.rr-act-secret__envelope[data-unlocked="1"] .rr-act-secret__content { display: block; }
.rr-act-secret__content[hidden] { display: none; }
.rr-act-secret__content p { font-size: 1.2rem; line-height: 1.6; }
.rr-act-secret__skip { display: block; margin: 14px auto 0; color: var(--rr-color-muted); text-decoration: underline; background: transparent; }

/* -- Act 7 — Portals ----------------------------------------------------- */
.rr-act-portals__head { text-align: center; margin-bottom: 32px; }
.rr-portals { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.rr-portal {
	color: var(--rr-color-ink);
	background: #fff;
	border-radius: var(--rr-radius);
	overflow: hidden;
	box-shadow: var(--rr-shadow-1);
	transition: transform .25s ease, box-shadow .25s ease;
	display: flex; flex-direction: column;
}
.rr-portal:hover { transform: translateY(-4px); box-shadow: var(--rr-shadow-2); text-decoration: none; }
.rr-portal__door {
	position: relative; aspect-ratio: 4/3; overflow: hidden;
	background: var(--rr-color-paper-dark);
}
.rr-portal__door-inner { position: absolute; inset: 0; transition: transform .5s ease; }
.rr-portal:hover .rr-portal__door-inner { transform: scale(1.06); }
.rr-portal__door img { width: 100%; height: 100%; object-fit: cover; }
.rr-portal__door::after {
	content: ''; position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(31,27,22,.5) 100%);
}
.rr-portal__copy { padding: 18px 18px 22px; flex: 1; }
.rr-portal__copy h3 { margin: 6px 0 4px; }
.rr-portal__copy p { color: var(--rr-color-muted); margin-bottom: 8px; }
.rr-portal__cta { color: var(--rr-color-accent); font-weight: 700; }
@media (max-width: 800px) { .rr-portals { grid-template-columns: 1fr; } }

/* -- Related rail -------------------------------------------------------- */
.rr-related__head { text-align: center; margin-bottom: 22px; }
.rr-mini-card {
	flex: 0 0 240px;
	background: #fff;
	padding: 10px;
	border-radius: var(--rr-radius);
	box-shadow: var(--rr-shadow-1);
	color: var(--rr-color-ink);
	scroll-snap-align: start;
}
.rr-mini-card:hover { text-decoration: none; transform: translateY(-2px); }
.rr-mini-card__media { aspect-ratio: 4/3; background: var(--rr-color-paper-dark); border-radius: var(--rr-radius-sm); overflow: hidden; margin-bottom: 8px; }
.rr-mini-card__media img { width: 100%; height: 100%; object-fit: cover; }
.rr-mini-card h4 { margin: 0 0 2px; font-size: 1.05rem; line-height: 1.2; }
.rr-mini-card small { color: var(--rr-color-muted); }

/* -- Community + FAQ ----------------------------------------------------- */
.rr-community { display: grid; gap: 60px; }
.rr-faq__head { text-align: center; margin-bottom: 18px; }
.rr-faq__list { max-width: 800px; margin: 0 auto; }
.rr-faq__item {
	background: #fff; border-radius: var(--rr-radius-sm);
	padding: 14px 18px; margin-bottom: 10px;
	box-shadow: var(--rr-shadow-1);
}
.rr-faq__item summary { cursor: pointer; font-weight: 600; font-family: var(--rr-font-display); font-size: 1.15rem; }
.rr-faq__item p { margin: 8px 0 0; color: var(--rr-color-ink); }

/* -- Passport drawer ------------------------------------------------------ */
.rr-passport-drawer { position: fixed; inset: 0; z-index: 90; background: rgba(31,27,22,.4); }
.rr-passport-drawer[hidden] { display: none; }
.rr-passport-drawer__inner {
	position: absolute; right: 0; top: 0; bottom: 0; width: min(420px, 92vw);
	background: var(--rr-color-paper); padding: 28px;
	overflow-y: auto;
	box-shadow: -10px 0 30px rgba(31,27,22,.2);
}
.rr-passport-drawer__close { position: absolute; right: 14px; top: 10px; font-size: 24px; }
.rr-passport-drawer__sub { color: var(--rr-color-muted); }
.rr-passport-drawer__stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin: 16px 0 22px; }
.rr-passport-drawer__stats > div { background: #fff; border-radius: var(--rr-radius-sm); padding: 14px 10px; text-align: center; box-shadow: var(--rr-shadow-1); }
.rr-passport-drawer__stats span { display: block; font-family: var(--rr-font-display); font-weight: 700; font-size: 1.7rem; color: var(--rr-color-accent); }
.rr-passport-drawer__stats small { color: var(--rr-color-muted); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; }
.rr-passport-drawer__stamps { display: grid; grid-template-columns: repeat(auto-fill, minmax(70px, 1fr)); gap: 8px; }
.rr-passport-drawer__stamps span {
	background: var(--rr-color-accent); color: #fff;
	border-radius: 50%; aspect-ratio: 1; display: grid; place-items: center;
	font-weight: 700; font-size: 12px; text-align: center; padding: 4px;
}

/* -- 404 ----------------------------------------------------------------- */
.rr-404 { max-width: 600px; margin: 80px auto; padding: 0 var(--rr-pad); text-align: center; }

/* Language switcher (i18n) — fixed bottom-right, above the season decor */
.rr-lang-switcher {
	position: fixed;
	right: 14px; bottom: 14px;
	display: inline-flex; gap: 4px;
	z-index: 28;
	background: rgba(31,27,22,.85);
	backdrop-filter: blur(6px);
	border-radius: 999px;
	padding: 4px;
}
.rr-lang-switcher__opt {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 36px; padding: 4px 10px;
	color: #FAF6EC; font-size: 11px; font-weight: 700; letter-spacing: .1em;
	border-radius: 999px;
	text-decoration: none;
	transition: background .15s ease;
}
.rr-lang-switcher__opt:hover { background: rgba(255,255,255,.1); text-decoration: none; }
.rr-lang-switcher__opt.is-active { background: var(--rr-color-accent); color: #fff; }

/* Season decoration — anchored to the viewport edge */
.rr-season-decor {
	position: fixed;
	right: 14px; top: 84px;
	display: flex; flex-direction: column; gap: 10px;
	font-size: 26px;
	opacity: .55;
	pointer-events: none;
	z-index: 25;
}
.rr-season-decor__m { display: inline-block; transform: rotate(-6deg); }
.rr-season-decor__m:nth-child(even) { transform: rotate(8deg); }
@media (max-width: 720px) { .rr-season-decor { font-size: 20px; right: 6px; top: 70px; } }

/* ===================================================================== */
/*  PRINT ZINE — authentic paper feel (deckle edges, foxing, drop caps)   */
/* ===================================================================== */

.rr-recipe--magazine {
	background:
		radial-gradient(ellipse at 50% 0%, rgba(31,27,22,.05) 0%, transparent 40%),
		linear-gradient(180deg, #EEE6D2 0%, #E5DBBE 100%);
	padding: 40px 0;
}

.rr-recipe--magazine .rr-mag {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 var(--rr-pad);
}

.rr-page {
	position: relative;
	min-height: 90vh;
	background:
		url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='1' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.55  0 0 0 0 0.42  0 0 0 0 0.28  0 0 0 0.08 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"),
		url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='600'%3E%3Cg fill='%23bf9c5a' opacity='0.07'%3E%3Ccircle cx='80' cy='120' r='2'/%3E%3Ccircle cx='240' cy='60' r='1.5'/%3E%3Ccircle cx='480' cy='180' r='2.2'/%3E%3Ccircle cx='560' cy='420' r='1.8'/%3E%3Ccircle cx='120' cy='460' r='2.5'/%3E%3Ccircle cx='380' cy='520' r='1.6'/%3E%3Ccircle cx='320' cy='280' r='1.2'/%3E%3C/g%3E%3C/svg%3E"),
		var(--rr-color-paper);
	border-radius: 2px;
	padding: clamp(28px, 5vw, 64px);
	margin: 0 0 56px;
	scroll-margin-top: 70px;
	overflow: hidden;
	isolation: isolate;
	box-shadow:
		0 1px 0 rgba(31, 27, 22, .12),
		0 14px 24px -16px rgba(31, 27, 22, .25),
		0 60px 80px -50px rgba(31, 27, 22, .35),
		inset 24px 0 60px -36px rgba(31, 27, 22, .25);
}

/* Deckle / torn paper edge along the bottom of each page */
.rr-page::after {
	content: '';
	position: absolute; left: 0; right: 0; bottom: -1px;
	height: 14px;
	background:
		url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 14' preserveAspectRatio='none'%3E%3Cpath d='M0,0 L200,0 L200,6 C190,9 180,4 170,7 C160,11 150,5 140,9 C130,12 120,4 110,8 C100,12 90,5 80,9 C70,13 60,4 50,8 C40,12 30,3 20,7 C10,11 5,5 0,8 Z' fill='%23EEE6D2'/%3E%3C/svg%3E") center/100% 100% repeat-x;
	pointer-events: none; z-index: 4;
}

/* Subtle inner vignette */
.rr-page::before {
	content: '';
	position: absolute; inset: 0;
	background:
		radial-gradient(ellipse at 0% 0%,   rgba(255,255,255,.5) 0%, transparent 35%),
		radial-gradient(ellipse at 100% 100%, rgba(31,27,22,.06) 0%, transparent 50%);
	pointer-events: none;
	z-index: 0;
}

.rr-page > * { position: relative; z-index: 1; }

/* Stamp-style page number — ink-stamped, slight rotation, double border */
.rr-page__corner-num {
	position: absolute;
	right: 36px; bottom: 28px;
	min-width: 60px; height: 60px; padding: 0 16px;
	background: transparent;
	color: var(--rr-color-accent);
	display: grid; place-items: center;
	font-family: "Playfair Display", Georgia, serif;
	font-style: italic;
	font-weight: 900;
	font-size: 2.4rem;
	letter-spacing: -.02em;
	border: 3px double var(--rr-color-accent);
	border-radius: 6px;
	transform: rotate(-5deg);
	z-index: 2;
	box-shadow: none;
	opacity: .82;
	filter: contrast(1.05);
}
.rr-page__corner-num::before { content: '·'; margin-right: 6px; opacity: .5; }
.rr-page__corner-num::after  { content: '·'; margin-left: 6px;  opacity: .5; }

/* --- Masthead strip at the very top of every page --- */
.rr-page__head {
	position: relative;
	margin-bottom: 22px;
	padding: 0 0 14px 0;
	border-bottom: 1.5px solid var(--rr-color-ink);
}
.rr-page__head::after {
	/* second hairline below the masthead — classic zine "double rule" */
	content: '';
	position: absolute; left: 0; right: 0; bottom: -5px;
	border-top: 1px solid rgba(31,27,22,.4);
}
.rr-page__head--cook { margin-top: 44px; }

.rr-page__kicker {
	display: inline-flex; align-items: center; gap: 10px;
	font-family: var(--rr-font-body); font-weight: 800;
	letter-spacing: .22em; text-transform: uppercase; font-size: 12px;
	color: var(--rr-color-accent);
}
.rr-page__head > .rr-page__kicker::before { content: '— '; letter-spacing: 0; }
.rr-page__head > .rr-page__kicker::after  { content: ' —'; letter-spacing: 0; }
.rr-page__head h2 { font-style: italic; margin-top: 4px; }

/* -------- Page 1 layout (hero) — asymmetric, more zine-like ------------- */
.rr-page--1 {
	display: grid;
	grid-template-columns: 1.05fr .95fr;
	grid-template-areas:
		"head     head"
		"title    title"
		"tagline  tagline"
		"hero     notes"
		"intro    notes"
		"pills    notes"
		"cpc      cpc"
		"nav      nav";
	gap: 22px 44px;
	align-items: start;
}
.rr-page--1 .rr-page__head    { grid-area: head; }
.rr-page--1 .rr-page__title {
	grid-area: title;
	margin: 0;
	/* Editorial display type — extra-tight, condensed feel, deep red */
	font-family: "Playfair Display", "Georgia", serif;
	font-size: clamp(2.8rem, 1.6rem + 6vw, 6rem);
	font-weight: 900;
	color: var(--rr-color-accent);
	line-height: .92;
	letter-spacing: -.018em;
	text-transform: uppercase;
}
.rr-page--1 .rr-pronounce {
	display: block;
	font-family: var(--rr-font-accent);
	color: var(--rr-color-deep);
	font-size: 1.45rem;
	font-weight: 400;
	margin-top: 10px;
	text-transform: none;
	letter-spacing: 0;
}
.rr-page--1 .rr-page__tagline {
	grid-area: tagline;
	font-family: var(--rr-font-accent);
	font-size: 1.7rem;
	line-height: 1.2;
	color: var(--rr-color-deep);
	margin: 0 0 6px;
}

/* Hero with washi tape — slightly rotated, taped to the page */
.rr-page--1 .rr-page__hero { grid-area: hero; margin: 0; position: relative; transform: rotate(-1.2deg); }
.rr-page--1 .rr-page__hero::before,
.rr-page--1 .rr-page__hero::after {
	/* Two strips of washi tape across the top corners */
	content: '';
	position: absolute;
	width: 88px; height: 22px;
	background: repeating-linear-gradient(
		45deg,
		rgba(232,160,168,.85),
		rgba(232,160,168,.85) 8px,
		rgba(245,192,74,.85)  8px,
		rgba(245,192,74,.85)  16px
	);
	box-shadow: 0 1px 3px rgba(0,0,0,.18);
	z-index: 2;
	pointer-events: none;
}
.rr-page--1 .rr-page__hero::before { left: -14px;  top: -10px; transform: rotate(-30deg); }
.rr-page--1 .rr-page__hero::after  { right: -14px; top: -10px; transform: rotate( 30deg); }
.rr-page--1 .rr-page__hero img {
	width: 100%;
	aspect-ratio: 4/5;
	object-fit: cover;
	border-radius: 1px;
	box-shadow:
		0 0 0 10px #fff,
		0 0 0 11px rgba(31,27,22,.08),
		0 14px 28px -10px rgba(31,27,22,.35);
}
.rr-page--1 .rr-page__hero .rr-doodle {
	position: absolute; left: -14px; bottom: -14px;
	width: 64px; color: var(--rr-color-accent);
	transform: rotate(-15deg); z-index: 3;
}

/* Multi-column intro body w/ a real drop cap on first paragraph */
.rr-page--1 .rr-page__intro {
	grid-area: intro;
	column-count: 2;
	column-gap: 28px;
	column-rule: 1px solid rgba(31,27,22,.12);
	font-size: 1.02rem;
	line-height: 1.55;
	text-align: justify;
	hyphens: auto;
}
.rr-page--1 .rr-page__intro p {
	margin: 0 0 .8em;
	break-inside: avoid;
}
.rr-page--1 .rr-page__intro p:first-of-type::first-letter {
	font-family: "Playfair Display", Georgia, serif;
	font-weight: 900;
	font-style: italic;
	float: left;
	font-size: 4.4rem;
	line-height: .85;
	padding: 6px 10px 0 0;
	color: var(--rr-color-accent);
	margin-top: 4px;
}

.rr-page--1 .rr-stat-pills    { grid-area: pills; }
.rr-page--1 .rr-page__notes   { grid-area: notes; display: grid; gap: 22px; align-content: start; }
.rr-page--1 .rr-cpc-callout   { grid-area: cpc; }
.rr-page--1 .rr-page__nav     { grid-area: nav; }
.rr-page--1 .rr-sticky-note--tags {
	grid-area: hero;
	align-self: end;
	justify-self: start;
	margin: 0 0 -10px -14px;
	max-width: 64%;
	z-index: 3;
	position: relative;
	transform: rotate(-3deg);
}

/* Stat pills — more "press card / stamp" feel, less generic chip */
.rr-page--1 .rr-stat-pills > span {
	background: transparent;
	border: 1.5px solid rgba(31,27,22,.65);
	border-radius: 0;
	padding: 6px 14px;
	font-family: var(--rr-font-body);
	font-weight: 700;
	letter-spacing: .04em;
	font-size: .82rem;
	text-transform: uppercase;
}

/* -------- Page 2 — ingredients & cook (print-instruction feel) ---------- */
.rr-mag-ingredients {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 36px;
	margin: 18px 0 40px;
}
.rr-mag-ingredients__group {
	background: transparent;
	padding: 0;
	border-top: 2px solid var(--rr-color-ink);
	padding-top: 14px;
	position: relative;
}
.rr-mag-ingredients__group--pantry { opacity: .9; }
.rr-mag-ingredients__title {
	display: inline-block;
	font-family: "Playfair Display", Georgia, serif;
	font-style: italic;
	background: transparent;
	color: var(--rr-color-accent);
	padding: 0;
	border-radius: 0;
	transform: none;
	font-size: 1.4rem;
	font-weight: 900;
	letter-spacing: -.01em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.rr-mag-ingredients__group:nth-child(3n)   .rr-mag-ingredients__title { color: var(--rr-color-deep); }
.rr-mag-ingredients__group:nth-child(3n+2) .rr-mag-ingredients__title { color: var(--rr-color-leaf); }
.rr-mag-ingredients ul { list-style: none; padding: 0; margin: 0; }
.rr-mag-ingredients li {
	padding: 7px 0 7px 24px;
	border-bottom: 1px dotted rgba(31,27,22,.22);
	font-size: 1rem;
	line-height: 1.45;
	position: relative;
}
.rr-mag-ingredients li::before {
	content: '';
	position: absolute; left: 0; top: 11px;
	width: 12px; height: 12px;
	border: 1.5px solid rgba(31,27,22,.55);
	border-radius: 2px;
	background: rgba(255,255,255,.4);
}
.rr-mag-ingredients li:last-child { border-bottom: 0; }
.rr-mag-ingredients li strong {
	font-family: "Playfair Display", Georgia, serif;
	color: var(--rr-color-accent);
	font-weight: 700;
	margin-right: 6px;
	font-variant-numeric: oldstyle-nums;
}

/* Cook steps as printed instructions — drop number, ruled paper feel */
.rr-mag-steps {
	list-style: none;
	padding: 0;
	margin: 0 0 32px;
	counter-reset: rrstep;
	display: grid;
	gap: 32px;
}
.rr-mag-step {
	display: grid;
	grid-template-columns: 82px 1.4fr .8fr;
	gap: 22px;
	align-items: start;
	background: transparent;
	padding: 18px 0 22px 0;
	border-bottom: 1px solid rgba(31,27,22,.18);
	transition: none;
}
.rr-mag-step:last-child { border-bottom: 0; }
.rr-mag-step:hover { transform: none; box-shadow: none; }
.rr-mag-step__num {
	width: 72px; height: 72px;
	background: transparent;
	color: var(--rr-color-accent);
	border: 3px solid var(--rr-color-accent);
	border-radius: 50%;
	display: grid; place-items: center;
	font-family: "Playfair Display", Georgia, serif;
	font-style: italic;
	font-size: 2.4rem;
	font-weight: 900;
	box-shadow: none;
}
.rr-mag-step__title {
	margin: 0 0 6px;
	font-family: "Playfair Display", Georgia, serif;
	font-style: italic;
	font-size: 1.35rem;
	text-transform: none;
	letter-spacing: 0;
	color: var(--rr-color-deep);
	font-weight: 700;
}
.rr-mag-step__body p { margin: 0; font-size: 1.02rem; line-height: 1.55; }
.rr-mag-step__media .rr-polaroid {
	padding: 8px 8px 36px;
	transform: rotate(2deg);
	position: relative;
}
.rr-mag-step__media .rr-polaroid::before {
	/* Washi tape on each step polaroid */
	content: '';
	position: absolute; top: -10px; left: 50%;
	transform: translateX(-50%) rotate(-2deg);
	width: 70px; height: 18px;
	background:
		repeating-linear-gradient(45deg,
			rgba(232,160,168,.75) 0 6px,
			rgba(255,255,255,.5) 6px 10px);
	box-shadow: 0 1px 2px rgba(0,0,0,.15);
}
.rr-mag-step__media .rr-polaroid img { aspect-ratio: 1; max-width: 210px; }
.rr-mag-step:nth-child(even) .rr-mag-step__media .rr-polaroid { transform: rotate(-2.5deg); }

@media (max-width: 720px) {
	.rr-mag-step { grid-template-columns: 60px 1fr; }
	.rr-mag-step__num { width: 56px; height: 56px; font-size: 1.8rem; }
	.rr-mag-step__media { grid-column: 1 / -1; justify-self: center; }
}

.rr-mag-pairings { background: var(--rr-color-paper-dark); border-radius: var(--rr-radius-sm); padding: 16px 20px; margin-top: 18px; }
.rr-mag-pairings__items { display: flex; gap: 24px; flex-wrap: wrap; margin-top: 8px; font-family: var(--rr-font-accent); font-size: 1.3rem; }
.rr-mag-pairings__icon { font-size: 1.8rem; margin-right: 6px; }

/* -------- Page 3 — clippings + scrapbook feel ------------------------- */
.rr-variations {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 22px;
	margin-bottom: 36px;
}
.rr-variation {
	background: transparent;
	border-radius: 0;
	padding: 18px 4px 4px 4px;
	border-top: 2px solid var(--rr-color-accent);
	border-radius: 0;
	transform: rotate(-.5deg);
}
.rr-variation:nth-child(2n)   { border-top-color: var(--rr-color-leaf);   transform: rotate(.6deg); }
.rr-variation:nth-child(3n)   { border-top-color: var(--rr-color-sun);    transform: rotate(-.8deg); }
.rr-variation:nth-child(4n)   { border-top-color: var(--rr-color-accent2); transform: rotate(.4deg); }
.rr-variation__icon {
	display: inline-block;
	font-size: 1.6rem;
	margin-bottom: 4px;
	transform: rotate(-3deg);
}
.rr-variation h4 {
	margin: 0 0 6px;
	font-family: "Playfair Display", Georgia, serif;
	font-style: italic;
	font-size: 1.1rem;
	text-transform: none;
	letter-spacing: 0;
	font-weight: 700;
}
.rr-variation p  { margin: 0; font-size: .98rem; color: var(--rr-color-ink); line-height: 1.45; }

.rr-goodfor { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-bottom: 36px; }
.rr-goodfor__card {
	background: transparent;
	border: 1.5px solid var(--rr-color-leaf);
	border-radius: 4px;
	padding: 20px 22px;
	position: relative;
}
.rr-goodfor__card--green { background: linear-gradient(135deg, rgba(223,232,200,.7) 0%, rgba(197,222,170,.7) 100%); }
.rr-goodfor__card--blue  { background: linear-gradient(135deg, rgba(214,228,240,.7) 0%, rgba(191,217,238,.7) 100%); border-color: var(--rr-color-accent2); }
.rr-goodfor__card ul     { list-style: none; padding: 0; margin: 10px 0 0; font-size: 1rem; }
.rr-goodfor__card li     { padding: 5px 0 5px 22px; position: relative; }
.rr-goodfor__card li::before {
	content: '✓';
	position: absolute; left: 0; top: 4px;
	font-family: "Playfair Display", Georgia, serif;
	font-weight: 900;
	color: var(--rr-color-leaf);
}
.rr-goodfor__card--blue li::before { color: var(--rr-color-accent2); }
@media (max-width: 720px) { .rr-goodfor { grid-template-columns: 1fr; } }

.rr-bottomwall {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 18px;
	margin-bottom: 32px;
}
.rr-sticky-note--big { transform: none; }
.rr-sticky-note--big ul { list-style: none; padding: 0; margin: 8px 0 0; font-family: var(--rr-font-body); font-size: .98rem; }
.rr-sticky-note--big li { padding: 2px 0; }

/* Stat pills */
.rr-stat-pills {
	display: flex; flex-wrap: wrap; gap: 10px;
	margin: 18px 0;
}
.rr-stat-pills > span {
	background: var(--rr-color-paper-dark);
	padding: 8px 14px; border-radius: 999px;
	font-weight: 600; font-size: .95rem;
}

/* Page navigation footer (per-page) */
.rr-page__nav {
	display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
	margin-top: 32px; padding-top: 24px;
	border-top: 1.5px dashed rgba(31,27,22,.18);
}
.rr-page__hint { width: 100%; text-align: center; color: var(--rr-color-muted); margin-top: 8px; font-size: 13px; }

/* Floating side page rail (numbered 1-2-3) */
.rr-page-rail {
	position: fixed;
	right: 18px; top: 50%; transform: translateY(-50%);
	display: flex; flex-direction: column; gap: 8px;
	z-index: 40;
}
.rr-page-rail__btn {
	width: 44px; height: 44px; border-radius: 50%;
	background: #fff; color: var(--rr-color-ink);
	font-family: var(--rr-font-display); font-weight: 700; font-size: 1.1rem;
	box-shadow: var(--rr-shadow-1);
	border: 2px solid transparent;
	transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.rr-page-rail__btn[data-active] {
	background: var(--rr-color-accent); color: #fff;
	border-color: var(--rr-color-deep);
	transform: scale(1.1);
}
.rr-page-rail__btn:hover { transform: scale(1.06); }
@media (max-width: 720px) {
	.rr-page-rail { bottom: 90px; top: auto; right: auto; left: 50%; transform: translateX(-50%); flex-direction: row; }
	.rr-page-rail__btn { width: 38px; height: 38px; font-size: 1rem; }
}

/* Finishing strip */
.rr-act-finish { margin-top: 36px; text-align: center; }
.rr-act-finish__strip {
	display: inline-block;
	background: var(--rr-color-deep); color: var(--rr-color-paper);
	font-family: var(--rr-font-display); font-weight: 700; letter-spacing: .08em;
	padding: 10px 24px; border-radius: 4px;
	transform: rotate(-1deg);
	font-size: 1.15rem;
}
.rr-act-finish__cta { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; margin: 18px 0; }
.rr-act-finish__tag { font-family: var(--rr-font-accent); font-size: 1.3rem; color: var(--rr-color-deep); }

/* --------- Photo wall --------- */
.rr-photo-wall { margin: 40px 0 30px; }
.rr-photo-wall__head {
	display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
	margin-bottom: 16px;
}
.rr-photo-wall__head h3 { margin: 0; }
.rr-photo-wall__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 16px;
}
.rr-photo-wall__empty { color: var(--rr-color-muted); font-style: italic; font-family: var(--rr-font-accent); font-size: 1.25rem; }
.rr-photo-card {
	background: #fff;
	border-radius: var(--rr-radius-sm);
	overflow: hidden;
	box-shadow: var(--rr-shadow-1);
	margin: 0;
}
.rr-photo-card img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.rr-photo-card figcaption { padding: 10px 12px 14px; font-size: .9rem; }
.rr-photo-card figcaption strong { display: block; font-family: var(--rr-font-display); font-size: 1rem; margin-bottom: 2px; }

.rr-photo-form {
	border: 0; padding: 0; background: transparent;
	max-width: 480px; width: 92vw;
	border-radius: var(--rr-radius);
}
.rr-photo-form::backdrop { background: rgba(31,27,22,.55); }
.rr-photo-form form {
	background: var(--rr-color-paper);
	padding: 28px;
	border-radius: var(--rr-radius);
	box-shadow: var(--rr-shadow-2);
	position: relative;
}
.rr-photo-form h3 { margin-top: 0; }
.rr-photo-form__sub { color: var(--rr-color-muted); margin-bottom: 18px; }
.rr-photo-form label { display: block; margin-bottom: 12px; }
.rr-photo-form label > span { display: block; font-weight: 600; margin-bottom: 4px; }
.rr-photo-form input[type="text"],
.rr-photo-form textarea,
.rr-photo-form input[type="file"] {
	width: 100%; padding: 10px 12px;
	border-radius: var(--rr-radius-sm);
	border: 1px solid rgba(31,27,22,.15);
	background: #fff;
	font: inherit;
}
.rr-photo-form__consent { font-size: 13px; display: flex; gap: 8px; align-items: start; }
.rr-photo-form__consent input { margin-top: 4px; }
.rr-photo-form__close { position: absolute; right: 12px; top: 8px; font-size: 26px; }
.rr-photo-form__actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 8px; }
.rr-photo-form__status { margin-top: 10px; font-size: 13px; }
.rr-photo-form__status[data-state="error"] { color: #B41E1A; }
.rr-photo-form__status[data-state="ok"]    { color: #2E7D32; }

/* --------- Rewarded interstitial (fallback) --------- */
.rr-rewarded-overlay {
	position: fixed; inset: 0; z-index: 250;
	background: rgba(31,27,22,.85);
	display: grid; place-items: center;
	padding: 20px;
	--rr-rewarded-accent: var(--rr-color-accent);
}
.rr-rewarded-card {
	background: var(--rr-color-deep); color: var(--rr-color-paper);
	border-radius: var(--rr-radius);
	max-width: 480px; width: 100%;
	overflow: hidden;
	box-shadow: 0 20px 60px rgba(0,0,0,.5),
		0 0 0 1px var(--rr-rewarded-accent);
}
.rr-rewarded-tag {
	background: var(--rr-rewarded-accent); color: #fff;
	font-size: 11px; font-weight: 800; letter-spacing: .2em;
	padding: 6px 14px; text-transform: uppercase;
}
.rr-rewarded-video {
	display: block; width: 100%; aspect-ratio: 16/9;
	background: #000; object-fit: cover;
}
.rr-rewarded-text {
	padding: 36px 24px;
	font-family: var(--rr-font-display);
	font-size: 1.3rem;
	line-height: 1.4;
	text-align: center;
	color: var(--rr-color-paper);
}
.rr-rewarded-bar {
	height: 4px; background: rgba(255,255,255,.15);
}
.rr-rewarded-bar__fill {
	height: 100%; width: 0;
	background: var(--rr-rewarded-accent);
	transition: width .9s linear;
}
.rr-rewarded-footer {
	padding: 14px 18px;
	display: flex; align-items: center; justify-content: space-between; gap: 10px;
	background: rgba(0,0,0,.25);
	font-size: 14px;
	flex-wrap: wrap;
}
.rr-rewarded-link {
	color: var(--rr-rewarded-accent) !important;
	font-weight: 600;
	text-decoration: underline;
	margin-left: auto;
}
.rr-rewarded-skip {
	background: var(--rr-rewarded-accent);
	color: #fff;
	padding: 8px 16px;
	border-radius: 999px;
	font-weight: 600;
	opacity: 1;
}
.rr-rewarded-skip[disabled] { opacity: .4; cursor: not-allowed; background: rgba(255,255,255,.15); }

/* --------- Cooking mode (fullscreen) --------- */
.rr-cook-mode {
	position: fixed; inset: 0; z-index: 200;
	background: var(--rr-color-deep);
	color: var(--rr-color-paper);
	display: flex; flex-direction: column;
}
.rr-cook-mode[hidden] { display: none; }
.rr-cook-mode__top {
	display: flex; gap: 8px; align-items: center;
	padding: 16px 24px;
	background: rgba(0,0,0,.25);
	flex-wrap: wrap;
}
.rr-cook-mode__top > * { color: var(--rr-color-paper); }
.rr-cook-mode__exit { font-weight: 600; }
.rr-cook-mode__voice, .rr-cook-mode__wake {
	background: rgba(255,255,255,.1); padding: 8px 14px; border-radius: 999px; font-weight: 600;
}
.rr-cook-mode__voice[data-on="1"], .rr-cook-mode__wake[data-on="1"] {
	background: var(--rr-color-accent);
}
.rr-cook-mode__pos { margin-left: auto; opacity: .85; font-weight: 600; }
.rr-cook-mode__stage {
	flex: 1;
	display: grid; place-items: center;
	padding: 28px;
	overflow-y: auto;
}
.rr-cook-card { max-width: 720px; text-align: center; }
.rr-cook-card[hidden] { display: none; }
.rr-cook-card__num {
	width: 110px; height: 110px; border-radius: 50%;
	background: var(--rr-color-accent); color: #fff;
	display: grid; place-items: center;
	font-family: var(--rr-font-display); font-size: 3rem; font-weight: 700;
	margin: 0 auto 22px;
	box-shadow: var(--rr-shadow-2);
}
.rr-cook-card__title { font-size: clamp(1.8rem, 1.3rem + 2vw, 3rem); color: var(--rr-color-paper); margin-bottom: 16px; }
.rr-cook-card__body  { font-size: clamp(1.15rem, 1rem + .7vw, 1.5rem); line-height: 1.5; color: rgba(248, 239, 224, .9); }
.rr-timer--big {
	background: var(--rr-color-accent); color: #fff;
	padding: 14px 22px; font-size: 1.1rem;
	margin-top: 22px;
}
.rr-cook-mode__nav {
	display: flex; gap: 12px; justify-content: center;
	padding: 18px;
	background: rgba(0,0,0,.25);
}
.rr-cook-mode__hint { text-align: center; padding: 0 18px 18px; opacity: .65; font-size: 14px; font-family: var(--rr-font-accent); font-size: 1.1rem; }
.rr-cook-chain-btn { margin: 0 8px; }
.rr-cook-chain-status { text-align: center; color: var(--rr-color-sun); font-weight: 600; padding: 0 18px; margin: 0 0 8px; }

/* --------- Layout: pages stack vertically; hide them all when in cook mode --------- */
body.rr-cooking { overflow: hidden; }

/* Mobile adjustments */
@media (max-width: 820px) {
	.rr-page--1 {
		grid-template-columns: 1fr;
		grid-template-areas:
			"head"
			"title"
			"tagline"
			"hero"
			"intro"
			"pills"
			"notes"
			"cpc"
			"nav";
	}
	.rr-page--1 .rr-sticky-note--tags { margin: -30px auto 0; max-width: 80%; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
	.rr-page-rail__btn { transition: none; }
	.rr-mag-step { transition: none; }
}
