/* ============================================================================
   Rezeptbuch - "Heirloom" design system
   A family recipe box, rendered with editorial precision.
   Signature: warm linen paper, Fraunces display serif, pine-green + brass,
   category "tabs" (colored dividers), measurements set like a kitchen ledger.
   ========================================================================== */

/* ---- Self-hosted fonts (no runtime third-party calls) ---------------------- */
@font-face {
  font-family: "Fraunces";
  src: url("/static/fonts/fraunces-wght.woff2") format("woff2-variations");
  font-weight: 300 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Fraunces";
  src: url("/static/fonts/fraunces-wght-italic.woff2") format("woff2-variations");
  font-weight: 300 700;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Hanken Grotesk";
  src: url("/static/fonts/hanken-wght.woff2") format("woff2-variations");
  font-weight: 300 800;
  font-style: normal;
  font-display: swap;
}

/* ---- Design tokens --------------------------------------------------------- */
:root {
  color-scheme: light dark;

  /* Type */
  --font-display: "Fraunces", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --font-body: "Hanken Grotesk", ui-sans-serif, -apple-system, BlinkMacSystemFont,
    "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  --font-mono: ui-monospace, "SF Mono", "Cascadia Code", "JetBrains Mono", Menlo,
    Consolas, monospace;

  /* Fluid type scale (base 16px, ~1.2/1.25 ratio, all rem so it survives zoom) */
  --step--1: clamp(0.83rem, 0.80rem + 0.15vw, 0.89rem);
  --step-0:  clamp(1.00rem, 0.96rem + 0.20vw, 1.0625rem);
  --step-1:  clamp(1.20rem, 1.13rem + 0.35vw, 1.33rem);
  --step-2:  clamp(1.44rem, 1.32rem + 0.60vw, 1.66rem);
  --step-3:  clamp(1.73rem, 1.54rem + 0.95vw, 2.07rem);
  --step-4:  clamp(2.07rem, 1.78rem + 1.45vw, 2.59rem);
  --step-5:  clamp(2.49rem, 2.00rem + 2.45vw, 3.40rem);

  /* Spacing (4px base) */
  --sp-1: .25rem; --sp-2: .5rem;  --sp-3: .75rem; --sp-4: 1rem;
  --sp-5: 1.5rem; --sp-6: 2rem;   --sp-7: 3rem;   --sp-8: 4rem; --sp-9: 6rem;

  --measure: 66ch;
  --radius-sm: 8px; --radius-md: 12px; --radius-lg: 18px; --radius-xl: 26px;
  --radius-pill: 999px;

  /* Motion */
  --ease: cubic-bezier(0.2, 0, 0, 1);
  --dur: 170ms;

  /* Palette - light (warm linen, pine green, brass) */
  --paper:      #F5F0E6;
  --paper-2:    #EFE8DA;
  --surface:    #FDFBF6;
  --ink:        #23201A;
  --muted:      #6A6357;
  --primary:    #2C5545;
  --primary-ink:#234A3B;
  --brass:      #9C6B1E;
  --brass-ink:  #855A17;
  --border:     #E2D9C7;
  --border-strong: #D2C6AE;
  --shadow-tint: 42, 36, 26;

  --shadow-1: 0 1px 2px rgba(var(--shadow-tint), .05), 0 1px 1px rgba(var(--shadow-tint), .04);
  --shadow-2: 0 2px 4px rgba(var(--shadow-tint), .05), 0 6px 16px rgba(var(--shadow-tint), .07);
  --shadow-3: 0 10px 30px rgba(var(--shadow-tint), .10), 0 3px 8px rgba(var(--shadow-tint), .06);
}

/* Dark mode (recomputed, not inverted) */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --paper:      #16130E;
    --paper-2:    #1C1810;
    --surface:    #201C14;
    --ink:        #F0E9DB;
    --muted:      #A79E8C;
    --primary:    #74B79C;
    --primary-ink:#8CCBB0;
    --brass:      #D8A85A;
    --brass-ink:  #E4BC77;
    --border:     #322C22;
    --border-strong: #443C2E;
    --shadow-tint: 0, 0, 0;
    --shadow-1: 0 1px 2px rgba(0,0,0,.3);
    --shadow-2: 0 2px 6px rgba(0,0,0,.4), 0 6px 18px rgba(0,0,0,.35);
    --shadow-3: 0 12px 34px rgba(0,0,0,.5), 0 3px 10px rgba(0,0,0,.4);
  }
}
[data-theme="dark"] {
  --paper:      #16130E;
  --paper-2:    #1C1810;
  --surface:    #201C14;
  --ink:        #F0E9DB;
  --muted:      #A79E8C;
  --primary:    #74B79C;
  --primary-ink:#8CCBB0;
  --brass:      #D8A85A;
  --brass-ink:  #E4BC77;
  --border:     #322C22;
  --border-strong: #443C2E;
  --shadow-tint: 0, 0, 0;
  --shadow-1: 0 1px 2px rgba(0,0,0,.3);
  --shadow-2: 0 2px 6px rgba(0,0,0,.4), 0 6px 18px rgba(0,0,0,.35);
  --shadow-3: 0 12px 34px rgba(0,0,0,.5), 0 3px 10px rgba(0,0,0,.4);
}

/* ---- Category accents (the "recipe box tabs") ------------------------------ */
.cat-main      { --cat: #2C5545; }
.cat-soup      { --cat: #B0722A; }
.cat-salad     { --cat: #6E7A34; }
.cat-baking    { --cat: #A85A43; }
.cat-dessert   { --cat: #8E4A63; }
.cat-breakfast { --cat: #BE8A2C; }
.cat-drink     { --cat: #3E6B78; }
[data-theme="dark"] .cat-main      { --cat: #6FB79B; }
[data-theme="dark"] .cat-soup      { --cat: #E0A45C; }
[data-theme="dark"] .cat-salad     { --cat: #AEBB65; }
[data-theme="dark"] .cat-baking    { --cat: #E08E74; }
[data-theme="dark"] .cat-dessert   { --cat: #D080A0; }
[data-theme="dark"] .cat-breakfast { --cat: #E6BB60; }
[data-theme="dark"] .cat-drink     { --cat: #6FA8B8; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .cat-main      { --cat: #6FB79B; }
  :root:not([data-theme="light"]) .cat-soup      { --cat: #E0A45C; }
  :root:not([data-theme="light"]) .cat-salad     { --cat: #AEBB65; }
  :root:not([data-theme="light"]) .cat-baking    { --cat: #E08E74; }
  :root:not([data-theme="light"]) .cat-dessert   { --cat: #D080A0; }
  :root:not([data-theme="light"]) .cat-breakfast { --cat: #E6BB60; }
  :root:not([data-theme="light"]) .cat-drink     { --cat: #6FA8B8; }
}

/* ---- Reset / base ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  min-height: 100dvh;
  font-family: var(--font-body);
  font-size: var(--step-0);
  font-weight: 380;
  line-height: 1.65;
  color: var(--ink);
  background-color: var(--paper);
  background-image:
    radial-gradient(120% 90% at 100% 0%, color-mix(in oklab, var(--primary) 6%, transparent), transparent 60%),
    radial-gradient(100% 80% at 0% 0%, color-mix(in oklab, var(--brass) 5%, transparent), transparent 55%);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; height: auto; }
a { color: var(--primary-ink); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--ink); }
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.12;
  letter-spacing: -0.012em;
  font-optical-sizing: auto;
  text-wrap: balance;
}
p { text-wrap: pretty; }
:focus-visible { outline: 2.5px solid var(--primary); outline-offset: 3px; border-radius: 3px; }
::selection { background: color-mix(in oklab, var(--primary) 25%, transparent); }

/* ---- Layout helpers -------------------------------------------------------- */
.wrap { width: 100%; max-width: 74rem; margin-inline: auto; padding-inline: clamp(1rem, 4vw, 2.5rem); }
.wrap-narrow { max-width: 46rem; }
.skip-link {
  position: absolute; left: var(--sp-3); top: var(--sp-3); z-index: 100;
  background: var(--surface); color: var(--ink);
  padding: var(--sp-2) var(--sp-4); border-radius: var(--radius-md);
  border: 1px solid var(--border-strong); box-shadow: var(--shadow-2);
  transform: translateY(-160%); transition: transform var(--dur) var(--ease);
}
.skip-link:focus { transform: translateY(0); }
.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--step--1);
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); font-weight: 500;
}

/* ---- Site header ----------------------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 30;
  background: color-mix(in oklab, var(--paper) 86%, transparent);
  -webkit-backdrop-filter: saturate(1.4) blur(10px);
  backdrop-filter: saturate(1.4) blur(10px);
  border-bottom: 1px solid var(--border);
}
.site-header__inner {
  display: flex; align-items: center; gap: var(--sp-4);
  min-height: 4.25rem; padding-block: var(--sp-3);
  flex-wrap: wrap;
}
.brand { display: inline-flex; align-items: center; gap: var(--sp-3); text-decoration: none; color: var(--ink); }
.brand__mark {
  width: 2.4rem; height: 2.4rem; flex: none;
  display: grid; place-items: center;
  border-radius: 50%;
  background: var(--primary); color: #F5F0E6;
  font-family: var(--font-display); font-weight: 600; font-size: 1.25rem;
  box-shadow: var(--shadow-1);
}
.brand__name { font-family: var(--font-display); font-weight: 500; font-size: var(--step-2); line-height: 1; }
.brand__sub { display: block; font-family: var(--font-mono); font-size: .62rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--muted); margin-top: .28rem; }
.site-header__spacer { flex: 1 1 auto; }
.header-tools { display: inline-flex; align-items: center; gap: var(--sp-2); }

/* Segmented control (language + theme) */
.seg { display: inline-flex; background: var(--paper-2); border: 1px solid var(--border);
  border-radius: var(--radius-pill); padding: 3px; }
.seg a, .seg button {
  font: inherit; font-size: var(--step--1); font-weight: 600;
  min-height: 2.1rem; min-width: 2.6rem; padding: 0 var(--sp-3);
  display: inline-flex; align-items: center; justify-content: center; gap: .35rem;
  border: 0; background: transparent; color: var(--muted); cursor: pointer;
  border-radius: var(--radius-pill); text-decoration: none;
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.seg a[aria-current="true"], .seg button[aria-pressed="true"] {
  background: var(--surface); color: var(--ink); box-shadow: var(--shadow-1);
}
.seg a:hover, .seg button:hover { color: var(--ink); }
.icon-btn {
  min-width: 2.7rem; min-height: 2.7rem; display: inline-grid; place-items: center;
  border-radius: var(--radius-pill); border: 1px solid var(--border);
  background: var(--paper-2); color: var(--ink); cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.icon-btn:hover { background: var(--surface); border-color: var(--border-strong); }
.theme-toggle .moon { display: none; }
[data-theme="dark"] .theme-toggle .sun { display: none; }
[data-theme="dark"] .theme-toggle .moon { display: block; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .theme-toggle .sun { display: none; }
  :root:not([data-theme="light"]) .theme-toggle .moon { display: block; }
}

/* ---- Buttons --------------------------------------------------------------- */
.btn {
  font: inherit; font-weight: 600; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  min-height: 2.9rem; padding: 0 var(--sp-5);
  border-radius: var(--radius-pill); border: 1px solid transparent;
  text-decoration: none;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease),
    background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--primary); color: #F5F0E6; box-shadow: var(--shadow-1); }
[data-theme="dark"] .btn--primary { color: #16130E; }
@media (prefers-color-scheme: dark){ :root:not([data-theme="light"]) .btn--primary { color:#16130E; } }
.btn--primary:hover { box-shadow: var(--shadow-2); color: #F5F0E6; }
[data-theme="dark"] .btn--primary:hover { color: #16130E; }
.btn--ghost { background: var(--surface); color: var(--ink); border-color: var(--border-strong); }
.btn--ghost:hover { border-color: var(--primary); color: var(--ink); }

/* ---- Hero (collection intro) ---------------------------------------------- */
.hero { padding-block: clamp(2.5rem, 6vw, 4.5rem) clamp(1.5rem, 3vw, 2.5rem); }
.hero__eyebrow { margin-bottom: var(--sp-4); }
.hero h1 { font-size: var(--step-5); font-weight: 480; max-width: 18ch; }
.hero h1 em { font-style: italic; color: var(--primary-ink); font-weight: 480; }
.hero__lede { margin-top: var(--sp-4); font-size: var(--step-1); color: var(--muted); max-width: 52ch; }

/* ---- Search + filter ------------------------------------------------------- */
.toolbar { display: flex; flex-wrap: wrap; gap: var(--sp-4) var(--sp-5); align-items: center;
  padding-block: var(--sp-5); border-block: 1px solid var(--border); margin-bottom: var(--sp-6); }
.search { position: relative; flex: 1 1 18rem; min-width: 0; }
.search svg { position: absolute; left: var(--sp-4); top: 50%; transform: translateY(-50%);
  width: 1.15rem; height: 1.15rem; color: var(--muted); pointer-events: none; }
.search input {
  font: inherit; width: 100%; min-height: 2.9rem;
  padding: 0 var(--sp-4) 0 2.9rem;
  color: var(--ink); background: var(--surface);
  border: 1px solid var(--border-strong); border-radius: var(--radius-pill);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.search input::placeholder { color: var(--muted); }
.search input:focus-visible { outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 22%, transparent); }

.chips { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.chip {
  font: inherit; font-size: var(--step--1); font-weight: 600; cursor: pointer;
  display: inline-flex; align-items: center; gap: .45rem;
  min-height: 2.4rem; padding: 0 var(--sp-4);
  color: var(--muted); background: transparent;
  border: 1px solid var(--border-strong); border-radius: var(--radius-pill);
  text-decoration: none;
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.chip::before { content: ""; width: .6rem; height: .6rem; border-radius: 50%;
  background: var(--cat, var(--muted)); flex: none; }
.chip.is-all::before { display: none; }
.chip:hover { color: var(--ink); border-color: var(--primary); }
.chip[aria-current="true"] { color: var(--ink); background: var(--surface);
  border-color: var(--cat, var(--primary)); box-shadow: var(--shadow-1); }

.count { font-family: var(--font-mono); font-size: var(--step--1); color: var(--muted); }

/* ---- Recipe grid + cards --------------------------------------------------- */
.grid {
  display: grid; gap: clamp(1.1rem, 2.4vw, 1.75rem);
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 17rem), 1fr));
  padding-bottom: var(--sp-9);
}
.card {
  position: relative; display: flex; flex-direction: column;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden; text-decoration: none;
  color: var(--ink); box-shadow: var(--shadow-1);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-3); border-color: var(--border-strong); }
.card:focus-visible { outline: 2.5px solid var(--cat, var(--primary)); outline-offset: 3px; }
/* Typographic "cover" - the type is the art; category tints it */
.card__cover {
  position: relative; padding: var(--sp-5) var(--sp-5) var(--sp-4);
  min-height: 9.5rem; display: flex; flex-direction: column; justify-content: flex-end;
  background:
    linear-gradient(160deg, color-mix(in oklab, var(--cat) 16%, var(--surface)) 0%,
      color-mix(in oklab, var(--cat) 5%, var(--surface)) 60%, var(--surface) 100%);
  border-bottom: 1px solid var(--border);
}
.card__cover::before { /* colored tab, like a divider in a recipe box */
  content: ""; position: absolute; top: 0; left: var(--sp-5);
  width: 2.6rem; height: .35rem; border-radius: 0 0 4px 4px; background: var(--cat);
}
.card__cat { display: inline-flex; align-items: center; gap: .45rem; margin-bottom: var(--sp-2); }
.card__cat::before { content: ""; width: .55rem; height: .55rem; border-radius: 50%; background: var(--cat); }
.card__cat span { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--muted); font-weight: 600; }
.card__title { font-family: var(--font-display); font-size: var(--step-3); font-weight: 500; line-height: 1.08; }
.card__alt { margin-top: .3rem; font-style: italic; color: var(--muted); font-size: var(--step-0); }
.card__meta {
  display: flex; flex-wrap: wrap; gap: var(--sp-2) var(--sp-4); align-items: center;
  padding: var(--sp-4) var(--sp-5) var(--sp-5); margin-top: auto;
  font-family: var(--font-mono); font-size: var(--step--1); color: var(--muted);
}
.card__meta .m { display: inline-flex; align-items: center; gap: .4rem; }
.card__meta svg { width: 1rem; height: 1rem; color: var(--cat); }

/* ---- Empty state ----------------------------------------------------------- */
.empty { text-align: center; padding: var(--sp-9) var(--sp-4); }
.empty h2 { font-size: var(--step-3); margin-bottom: var(--sp-3); }
.empty p { color: var(--muted); margin-bottom: var(--sp-5); }

/* ---- Recipe detail --------------------------------------------------------- */
.recipe { padding-block: clamp(1.5rem, 4vw, 3rem) var(--sp-9); }
.backlink { display: inline-flex; align-items: center; gap: .4rem; font-weight: 600;
  font-size: var(--step--1); color: var(--muted); text-decoration: none; margin-bottom: var(--sp-5); }
.backlink:hover { color: var(--ink); }
.backlink svg { width: 1rem; height: 1rem; }
.recipe__head { margin-bottom: var(--sp-6); }
.recipe__cat { margin-bottom: var(--sp-4); }
.recipe__cat span { color: var(--cat); font-weight: 700; }
.recipe h1 { font-size: var(--step-5); font-weight: 480; }
.recipe__alt { margin-top: var(--sp-2); font-style: italic; color: var(--muted); font-size: var(--step-1); }
.recipe__intro { margin-top: var(--sp-4); font-size: var(--step-1); color: var(--muted); max-width: var(--measure); }

.facts { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-5); }
.fact {
  display: inline-flex; align-items: baseline; gap: .5rem;
  padding: var(--sp-2) var(--sp-4); background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--radius-pill);
}
.fact svg { width: 1rem; height: 1rem; color: var(--cat); align-self: center; }
.fact b { font-family: var(--font-mono); font-weight: 600; font-variant-numeric: tabular-nums; }
.fact span { font-size: var(--step--1); color: var(--muted); }

/* Two-column body: ingredients aside + method */
.recipe__body { display: grid; gap: clamp(1.75rem, 4vw, 3rem); margin-top: var(--sp-7);
  grid-template-columns: 1fr; align-items: start; }
@media (min-width: 56rem) {
  .recipe__body { grid-template-columns: minmax(15rem, 20rem) 1fr; }
  .ingredients { position: sticky; top: 5.5rem; }
}
.panel-title { font-family: var(--font-display); font-size: var(--step-2); font-weight: 500;
  margin-bottom: var(--sp-4); display: flex; align-items: center; gap: var(--sp-3); }
.panel-title::after { content: ""; height: 1px; flex: 1; background: var(--border); }

.ingredients {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--sp-5); box-shadow: var(--shadow-1);
}
.ingredients ul { list-style: none; }
.ing {
  display: grid; grid-template-columns: 1.4rem 1fr; gap: var(--sp-3);
  align-items: baseline; padding: var(--sp-2) 0; border-bottom: 1px dashed var(--border);
  cursor: pointer;
}
.ing:last-child { border-bottom: 0; }
.ing input { position: absolute; opacity: 0; width: 0; height: 0; }
.ing__box {
  width: 1.15rem; height: 1.15rem; margin-top: .18rem; flex: none; align-self: start;
  border: 1.5px solid var(--border-strong); border-radius: 5px; display: grid; place-items: center;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.ing__box svg { width: .8rem; height: .8rem; color: #F5F0E6; opacity: 0; transform: scale(.6);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease); }
.ing input:checked + .ing__box { background: var(--cat); border-color: var(--cat); }
.ing input:checked + .ing__box svg { opacity: 1; transform: scale(1); }
.ing input:focus-visible + .ing__box { outline: 2.5px solid var(--primary); outline-offset: 2px; }
.ing__text { transition: color var(--dur) var(--ease); }
.ing__qty { font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  font-weight: 600; color: var(--ink); }
.ing__note { color: var(--muted); }
.ing input:checked ~ .ing__text { color: var(--muted); text-decoration: line-through;
  text-decoration-color: var(--cat); }

.serving-note { margin-top: var(--sp-4); font-size: var(--step--1); color: var(--muted);
  display: flex; align-items: center; gap: .5rem; }
.serving-note svg { width: 1rem; height: 1rem; flex: none; }

/* Method steps */
.steps { list-style: none; counter-reset: step; display: grid; gap: var(--sp-5); }
.step { display: grid; grid-template-columns: auto 1fr; gap: var(--sp-4); align-items: start; }
.step__num {
  counter-increment: step; font-family: var(--font-display); font-weight: 600;
  font-size: var(--step-2); line-height: 1;
  width: 2.6rem; height: 2.6rem; flex: none; display: grid; place-items: center;
  color: var(--cat); background: color-mix(in oklab, var(--cat) 12%, var(--surface));
  border: 1px solid color-mix(in oklab, var(--cat) 30%, var(--border)); border-radius: 50%;
}
.step__num::before { content: counter(step); }
.step__text { padding-top: .35rem; max-width: 60ch; }

.notes { margin-top: var(--sp-7); padding: var(--sp-5); border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--brass) 8%, var(--surface));
  border: 1px solid color-mix(in oklab, var(--brass) 22%, var(--border)); }
.notes .panel-title::after { background: color-mix(in oklab, var(--brass) 30%, var(--border)); }
.notes p { max-width: var(--measure); }
.source { margin-top: var(--sp-6); font-size: var(--step--1); color: var(--muted); font-style: italic; }

/* ---- Footer ---------------------------------------------------------------- */
.site-footer { border-top: 1px solid var(--border); padding-block: var(--sp-7); margin-top: var(--sp-8);
  color: var(--muted); font-size: var(--step--1); }
.site-footer__inner { display: flex; flex-wrap: wrap; gap: var(--sp-4); justify-content: space-between; align-items: center; }

/* ---- Motion / print -------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; scroll-behavior: auto !important; }
}
@media print {
  .site-header, .site-footer, .toolbar, .backlink, .serving-note { display: none !important; }
  body { background: #fff; color: #000; }
  .ingredients, .card, .notes { box-shadow: none; }
  .recipe__body { grid-template-columns: 1fr; }
  .ingredients { position: static; }
}
