:root {
  --ink: #2b2622;
  --muted: #7a716a;
  --accent: #c2541f;      /* warm terracotta — appetite-forward */
  --bg: #fbf7f1;
  --card: #ffffff;
  --line: #ece4d8;
  --maxw: 920px;
}
* { box-sizing: border-box; }
body {
  margin: 0; color: var(--ink); background: var(--bg);
  font: 17px/1.6 -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.site-header {
  display: flex; align-items: center; justify-content: space-between;
  max-width: var(--maxw); margin: 0 auto; padding: 18px 20px;
}
.brand { font-weight: 800; font-size: 1.35rem; color: var(--ink); letter-spacing: -.5px; }
.site-header nav a { margin-left: 18px; font-weight: 600; }
main { max-width: var(--maxw); margin: 0 auto; padding: 8px 20px 48px; }

.hero { text-align: center; padding: 32px 0 24px; }
.hero h1 { font-size: 2.2rem; margin: 0 0 8px; letter-spacing: -1px; }
.intro { color: var(--muted); max-width: 640px; margin: 0 auto 18px; }
.cta, .recipe-form button {
  display: inline-block; background: var(--accent); color: #fff; font-weight: 700;
  padding: 12px 22px; border-radius: 8px; border: 0; cursor: pointer; font-size: 1rem;
}
.cta:hover { text-decoration: none; opacity: .92; }

.hero--image {
  background-size: cover; background-position: center; border-radius: 14px;
  min-height: 320px; display: flex; align-items: center; justify-content: center;
  padding: 32px 20px; margin-top: 8px; overflow: hidden;
}
.hero--image .hero-panel {
  background: rgba(255,255,255,.80); backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px); border-radius: 12px; padding: 22px 28px;
  max-width: 600px; box-shadow: 0 6px 28px rgba(0,0,0,.10);
}
.cat-banner {
  width: 100%; height: 200px; object-fit: cover; border-radius: 12px;
  display: block; margin: 8px 0 4px;
}

.group h2 { border-bottom: 2px solid var(--line); padding-bottom: 6px; margin-top: 36px; }
.recipe-grid {
  list-style: none; padding: 0; display: grid; gap: 18px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.card a {
  display: flex; flex-direction: column; background: var(--card); border: 1px solid var(--line);
  border-radius: 10px; overflow: hidden; height: 100%; color: var(--ink);
}
.card a:hover { text-decoration: none; box-shadow: 0 4px 16px rgba(0,0,0,.07); }
.card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.card-title { font-weight: 700; padding: 12px 12px 2px; }
.card-meta { color: var(--muted); font-size: .85rem; padding: 0 12px 12px; }

.recipe h1 { font-size: 2rem; letter-spacing: -.6px; margin-bottom: 6px; }
.summary { color: var(--muted); font-size: 1.05rem; }
.facts { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 16px;
  border-block: 1px solid var(--line); padding: 12px 0; margin: 18px 0; }
.facts strong { display: block; font-size: .72rem; text-transform: uppercase;
  letter-spacing: .5px; color: var(--muted); }
.hero-img { width: 100%; border-radius: 12px; margin: 8px 0 24px; }
.ingredients ul, .steps ol { padding-left: 22px; }
.ingredients li, .steps li { margin: 6px 0; }
.credit { color: var(--muted); font-size: .9rem; margin-top: 28px; }

.recipe-form { display: grid; gap: 14px; max-width: 640px; }
.recipe-form label { display: grid; gap: 4px; font-weight: 600; font-size: .9rem; }
.recipe-form input, .recipe-form textarea {
  font: inherit; padding: 9px 11px; border: 1px solid var(--line); border-radius: 7px;
  background: #fff;
}
.recipe-form .row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.fineprint { color: var(--muted); font-size: .8rem; font-weight: 400; }
.photo-field input[type=file] { font: inherit; font-size: .9rem; padding: 6px 0; }
.photo-preview { margin: 0; }
.photo-preview img { max-width: 100%; max-height: 260px; border-radius: 10px;
  border: 1px solid var(--line); display: block; }

.crumbs { color: var(--muted); font-size: .85rem; padding: 12px 0 0; }
.crumbs a { color: var(--muted); }
.crumbs a:hover { color: var(--accent); }
.group h2 a { color: var(--ink); }
.group h2 a:hover { color: var(--accent); text-decoration: none; }

.pantry-list { list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.pantry-list li a {
  display: inline-block; padding: 6px 12px; border: 1px solid var(--line);
  border-radius: 999px; background: var(--card); font-size: .9rem; color: var(--ink);
}
.pantry-list li a:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }
.affiliate-disclosure { color: var(--muted); margin: 4px 0 18px; }

.site-footer { max-width: var(--maxw); margin: 0 auto; padding: 24px 20px 48px;
  border-top: 1px solid var(--line); color: var(--muted); font-size: .9rem; }
.site-footer .meta { font-size: .8rem; }
@media (max-width: 560px) { .recipe-form .row { grid-template-columns: 1fr; } }

/* --- Accounts + community ------------------------------------------------- */
/* Nav auth state: default to signed-out until app.js resolves /auth/me. */
.js-username:empty { display: none; }
.js-username { font-weight: 700; }
body.is-signed-in .js-signin-label { display: none; }

.actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 4px 0 20px; }
.action {
  font: inherit; font-weight: 700; font-size: .92rem; cursor: pointer;
  background: #fff; color: var(--ink); border: 1px solid var(--line);
  border-radius: 999px; padding: 8px 16px;
}
.action:hover { border-color: var(--accent); color: var(--accent); }
.action.is-on { background: var(--accent); color: #fff; border-color: var(--accent); }
.action.js-vote.is-on { background: var(--accent); }
.action-meta { color: var(--muted); font-size: .9rem; }

.group--featured h2 { color: var(--accent); }

.made-it { border-top: 1px solid var(--line); margin-top: 28px; padding-top: 18px; }
.made-intro { color: var(--muted); margin: 0 0 10px; }
.made-form { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.made-form input[type=file] { font: inherit; font-size: .9rem; }

/* Account page: toggle panels on .is-authed. */
.signed-in-only { display: none; }
.js-account.is-authed .signed-in-only { display: block; }
.js-account.is-authed .signed-out-only { display: none; }

/* Book page: toggle on .needs-auth. */
.book-signin { display: none; }
.js-book.needs-auth .book-content { display: none; }
.js-book.needs-auth .book-signin { display: block; }
.collections-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.collections-list .muted { color: var(--muted); }
.recipe-grid .empty { color: var(--muted); grid-column: 1 / -1; }
