/* content.css — SEO content surface (food pages, calculator, hub).
   Layers on top of styles.css; reuses its tokens. Does NOT touch legal pages. */

/* ---------- shared content rhythm ---------- */
.prose { max-width: var(--measure); }
.prose > * + * { margin-top: var(--space-12); }
.section { padding-block: var(--space-24); }
.section + .section { border-top: 1px solid var(--color-rule); }
.eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-4);
  font-size: var(--text-sm); font-weight: 600; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--color-accent);
}
.crumbs { font-size: var(--text-sm); color: var(--color-ink-3); margin-bottom: var(--space-8); }
.crumbs a { color: var(--color-ink-2); }

/* ---------- featured-snippet answer card ---------- */
.answer {
  background: var(--color-accent-soft);
  border: 1px solid color-mix(in oklch, var(--color-accent) 22%, var(--color-rule));
  border-radius: var(--radius-lg);
  padding: var(--space-16);
  display: flex; gap: var(--space-12); align-items: center;
}
.answer__big {
  font-family: var(--font-display); font-weight: 600; line-height: 1;
  font-size: clamp(2.4rem, 1.6rem + 3vw, 3.4rem); color: var(--color-accent);
  white-space: nowrap;
}
.answer__big small { display: block; font-size: var(--text-sm); color: var(--color-ink-2); font-weight: 500; margin-top: var(--space-4); }
.answer p { margin: 0; color: var(--color-ink); }

/* ---------- nutrition table ---------- */
.nutri { width: 100%; border-collapse: collapse; font-size: var(--text-base); }
.nutri caption { text-align: left; font-weight: 600; margin-bottom: var(--space-8); color: var(--color-ink); }
.nutri th, .nutri td { padding: var(--space-8) var(--space-6); border-bottom: 1px solid var(--color-rule); text-align: right; }
.nutri th:first-child, .nutri td:first-child { text-align: left; }
.nutri thead th { color: var(--color-ink-3); font-weight: 600; font-size: var(--text-sm); }
.nutri tbody tr:hover { background: var(--color-paper-3); }
.nutri .row-kcal td { font-weight: 600; color: var(--color-accent); }

/* ---------- macro bar ---------- */
.macrobar { display: flex; height: 14px; border-radius: var(--radius-pill); overflow: hidden; border: 1px solid var(--color-rule); }
.macrobar span { display: block; }
.macrobar .m-p { background: oklch(58% 0.118 152); }
.macrobar .m-c { background: oklch(72% 0.12 80); }
.macrobar .m-f { background: oklch(68% 0.14 40); }
.macrolegend { display: flex; gap: var(--space-16); flex-wrap: wrap; font-size: var(--text-sm); color: var(--color-ink-2); margin-top: var(--space-8); }
.macrolegend i { width: 10px; height: 10px; border-radius: 3px; display: inline-block; margin-right: var(--space-4); vertical-align: middle; }

/* ---------- FAQ ---------- */
.faq details {
  border: 1px solid var(--color-rule); border-radius: var(--radius-md);
  padding: var(--space-8) var(--space-12); background: var(--color-paper-2);
}
.faq details + details { margin-top: var(--space-8); }
.faq summary { font-weight: 600; cursor: pointer; list-style: none; color: var(--color-ink); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; float: right; color: var(--color-accent); font-weight: 600; }
.faq details[open] summary::after { content: "–"; }
.faq details[open] summary { margin-bottom: var(--space-8); }
.faq p { margin: 0; color: var(--color-ink-2); }

/* ---------- install CTA band ---------- */
.cta-band {
  background: var(--color-ink); color: var(--color-on-accent);
  border-radius: var(--radius-lg); padding: var(--space-20) var(--space-16);
  display: flex; flex-wrap: wrap; gap: var(--space-16); align-items: center; justify-content: space-between;
}
.cta-band h2 { color: var(--color-paper); margin: 0 0 var(--space-4); font-size: var(--text-xl); }
.cta-band p { margin: 0; color: color-mix(in oklch, var(--color-paper) 78%, transparent); font-size: var(--text-sm); max-width: 42ch; }
.cta-band .stores { display: flex; gap: var(--space-8); flex-wrap: wrap; }
.store-btn {
  display: inline-flex; align-items: center; gap: var(--space-6);
  background: var(--color-paper); color: var(--color-ink);
  padding: var(--space-8) var(--space-12); border-radius: var(--radius-pill);
  font-weight: 600; font-size: var(--text-sm); white-space: nowrap;
}
.store-btn:hover { text-decoration: none; background: var(--color-paper-3); }

/* ---------- food hub grid ---------- */
.food-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: var(--space-8); }
.food-tile {
  display: flex; flex-direction: column; gap: var(--space-2);
  border: 1px solid var(--color-rule); border-radius: var(--radius-md);
  padding: var(--space-12); background: var(--color-paper-2); color: var(--color-ink);
}
.food-tile:hover { border-color: var(--color-rule-strong); transform: translateY(-2px); text-decoration: none; }
.food-tile b { font-weight: 600; }
.food-tile span { font-size: var(--text-sm); color: var(--color-ink-3); }
.cat-head { font-size: var(--text-sm); font-weight: 600; color: var(--color-ink-3); text-transform: uppercase; letter-spacing: 0.04em; margin: var(--space-16) 0 var(--space-6); }
.related { display: flex; flex-wrap: wrap; gap: var(--space-6); }
.related a { font-size: var(--text-sm); padding: var(--space-4) var(--space-8); border: 1px solid var(--color-rule); border-radius: var(--radius-pill); color: var(--color-ink-2); }

/* ---------- calculator ---------- */
.calc { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-16); align-items: start; }
.calc__form { display: grid; gap: var(--space-12); }
.field { display: grid; gap: var(--space-4); }
.field label { font-weight: 600; font-size: var(--text-sm); }
.field input, .field select {
  font: inherit; padding: var(--space-8) var(--space-8); border: 1px solid var(--color-rule-strong);
  border-radius: var(--radius-sm); background: var(--color-paper-2); color: var(--color-ink);
}
.field input:focus, .field select:focus { outline: 2px solid var(--color-focus); outline-offset: 1px; }
.seg { display: flex; gap: var(--space-4); }
.seg button {
  flex: 1; font: inherit; font-weight: 600; cursor: pointer; padding: var(--space-8);
  border: 1px solid var(--color-rule-strong); border-radius: var(--radius-sm);
  background: var(--color-paper-2); color: var(--color-ink-2);
}
.seg button[aria-pressed="true"] { background: var(--color-accent); color: var(--color-on-accent); border-color: var(--color-accent); }
.calc__out { background: var(--color-paper-2); border: 1px solid var(--color-rule); border-radius: var(--radius-lg); padding: var(--space-16); position: sticky; top: 84px; }
.calc__kcal { font-family: var(--font-display); font-size: clamp(2.6rem, 1.8rem + 3vw, 3.6rem); font-weight: 600; color: var(--color-accent); line-height: 1; }
.calc__kcal small { display: block; font-size: var(--text-sm); color: var(--color-ink-2); font-weight: 500; }
.calc__macros { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); margin-top: var(--space-16); text-align: center; }
.calc__macros div { border: 1px solid var(--color-rule); border-radius: var(--radius-md); padding: var(--space-8); }
.calc__macros b { display: block; font-size: var(--text-lg); }
.calc__macros span { font-size: var(--text-xs); color: var(--color-ink-3); text-transform: uppercase; letter-spacing: 0.04em; }

@media (max-width: 720px) {
  .calc { grid-template-columns: 1fr; }
  .calc__out { position: static; }
  .answer { flex-direction: column; align-items: flex-start; gap: var(--space-8); }
  .answer__big { white-space: normal; }
}
