/* ============================================================
   Biomy content-page primitives. Pairs with tokens.css + layout.js.
   Used by /about/, /privacy/, /recipes/, /fodmap/. (/flora/ adds its
   own --sky styles inline; --sky never appears here.)
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--cloud); color: var(--ink); font-size: var(--text-body); line-height: 1.65; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; }
:where(a, button):focus-visible { outline: 2px solid var(--mint); outline-offset: 3px; border-radius: 4px; }

/* ── Layout ── */
.wrap { max-width: 1180px; margin: 0 auto; padding-inline: var(--space-gutter); }
.wrap-narrow { max-width: 760px; margin: 0 auto; padding-inline: var(--space-gutter); }
.sec { padding: var(--space-section) 0; }

.bg-forest { background: var(--forest); color: var(--cloud); }
.bg-forest-deep { background: var(--forest-deep); color: var(--cloud); }
.bg-cloud { background: var(--cloud); color: var(--ink); }

/* ── Type ── */
.eyebrow-pill { display: inline-flex; align-items: center; gap: 8px; background: var(--forest-deep); border: 1px solid rgba(176,240,216,0.18); border-radius: var(--radius-pill); padding: 8px 16px; font-size: var(--text-small); letter-spacing: 0.08em; text-transform: uppercase; color: var(--cloud-soft); margin-bottom: 22px; }
.overline { font-size: var(--text-small); font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal); margin-bottom: 10px; }
.h1 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-hero); line-height: 1.03; letter-spacing: -0.03em; text-wrap: balance; }
.h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-h2); line-height: 1.1; letter-spacing: -0.02em; text-wrap: balance; }
.lead { font-size: 1.125rem; line-height: 1.6; max-width: 40em; text-wrap: pretty; }
.bg-forest .lead, .bg-forest-deep .lead, .bg-forest p, .bg-forest-deep p { color: var(--cloud-soft); }
.bg-cloud .lead, .bg-cloud p { color: var(--ink-soft); }
.prose p { margin-bottom: 1.1rem; max-width: 40em; }
.prose p:last-child { margin-bottom: 0; }
.prose strong { color: var(--ink); font-weight: 600; }
.bg-forest .prose strong, .bg-forest-deep .prose strong { color: var(--cloud); }
.accent-mint { color: var(--mint); }
.accent-mint-i { color: var(--mint); font-style: italic; }
.accent-teal { color: var(--teal); }
.accent-teal-i { color: var(--teal); font-style: italic; }
.small-line { font-size: var(--text-small); color: var(--cloud-soft); margin-top: 18px; }
.bg-cloud .small-line { color: var(--ink-soft); }
.stack > * + * { margin-top: 16px; }

/* ── Buttons (one CTA style: mint pill; plus ghost) ── */
.btn-row { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; margin-top: 30px; }
.btn-mint { display: inline-block; font-family: var(--font-body); font-weight: 500; font-size: 1rem; color: var(--forest-deep); background: var(--mint); border: 2px solid var(--mint); border-radius: var(--radius-pill); padding: 14px 30px; text-decoration: none; transition: transform .15s ease, filter .15s ease; }
.btn-mint:hover { transform: translateY(-2px); filter: brightness(1.05); }
.btn-ghost { display: inline-block; font-family: var(--font-body); font-weight: 500; font-size: 1rem; color: var(--mint); background: transparent; border: 2px solid rgba(176,240,216,0.5); border-radius: var(--radius-pill); padding: 14px 30px; text-decoration: none; transition: border-color .15s ease, transform .15s ease; }
.btn-ghost:hover { border-color: var(--mint); transform: translateY(-2px); }

/* ── Cards ── */
.card { background: #fff; border: 1px solid rgba(20,43,33,0.1); border-radius: var(--radius-card); padding: 28px; }
.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 34px; }
.stat-card { background: var(--forest-deep); color: var(--cloud); border-radius: var(--radius-card); padding: 28px; }
.stat-num { font-family: var(--font-display); font-weight: 700; font-size: 2.6rem; line-height: 1; color: var(--mint); margin-bottom: 10px; }
.stat-label { font-size: 0.9rem; color: var(--cloud-soft); line-height: 1.5; }

.not-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 34px; }
.not-card { display: flex; align-items: center; gap: 16px; background: #fff; border: 1px solid rgba(20,43,33,0.1); border-radius: var(--radius-card); padding: 22px 24px; font-size: 1rem; line-height: 1.45; }
.icon-disc { width: 40px; height: 40px; border-radius: 50%; background: rgba(99,178,175,0.16); color: var(--teal); display: grid; place-items: center; flex: none; }
.avatar-disc { width: 48px; height: 48px; border-radius: 50%; background: var(--teal); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; flex: none; }
.ic { width: 20px; height: 20px; flex: none; }

/* ── Icon lists (check / x) ── */
.icon-list { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
.icon-list li { display: flex; align-items: flex-start; gap: 12px; font-size: 1rem; line-height: 1.5; }
.icon-list .ic { margin-top: 1px; }
.ic-check { color: var(--teal); }
.ic-x { color: var(--ink-soft); }

/* ── Callout (teal left border) ── */
.callout { border-left: 3px solid var(--teal); background: rgba(99,178,175,0.08); border-radius: 0 var(--radius-card) var(--radius-card) 0; padding: 18px 24px; font-size: 0.98rem; line-height: 1.65; margin-top: 28px; }
.callout strong { font-weight: 600; }
.callout a { color: #2c6360; font-weight: 500; }

/* ── Vertical spine (FODMAP acronym) ── */
.spine { position: relative; margin-top: 40px; }
.spine::before { content: ""; position: absolute; left: 33px; top: 34px; bottom: 34px; width: 2px; background: var(--teal); opacity: 0.45; }
.spine-row { position: relative; display: flex; gap: 20px; align-items: center; padding: 14px 0; }
.spine-disc { width: 68px; height: 68px; border-radius: 50%; background: var(--forest); color: var(--mint); display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 38px; flex: none; z-index: 1; }
.spine-disc.invert { background: var(--mint); color: var(--forest-deep); }
.spine-body { flex: 1; }
.spine-name { font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; color: var(--ink); }
.spine-desc { font-size: 0.95rem; color: var(--ink-soft); line-height: 1.5; margin-top: 2px; }
.spine-icon { color: var(--teal); flex: none; }
.spine-icon .ic { width: 24px; height: 24px; }

/* ── Flag system ── */
.flags { display: flex; flex-direction: column; gap: 24px; margin-top: 40px; }
.flag { display: flex; gap: 18px; align-items: flex-start; }
.flag-disc { width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; flex: none; color: #fff; }
.flag-green .flag-disc { background: var(--flag-green); }
.flag-amber .flag-disc { background: var(--flag-amber); }
.flag-red .flag-disc { background: var(--flag-red); }
.flag-title { font-family: var(--font-display); font-weight: 700; font-size: 1.25rem; color: var(--cloud); }
.flag-sub { font-style: italic; color: var(--cloud-soft); margin: 2px 0 14px; }
.flag-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { font-size: 0.85rem; padding: 7px 13px; border-radius: var(--radius-pill); background: rgba(242,247,243,0.08); border: 1px solid rgba(242,247,243,0.14); color: var(--cloud-soft); }

/* ── Recipe cards (preview) ── */
.recipe-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 40px; }
.rec-card { background: #fff; border: 1px solid rgba(20,43,33,0.1); border-radius: var(--radius-card); overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: transform .15s ease, box-shadow .15s ease; }
.rec-card:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(20,43,33,0.08); }
.rec-media { aspect-ratio: 16 / 10; }
.rec-media img { width: 100%; height: 100%; object-fit: cover; }
.rec-body { padding: 20px 22px 24px; display: flex; flex-direction: column; gap: 8px; }
.rec-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.rec-tag { font-size: 0.68rem; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; padding: 4px 10px; border-radius: var(--radius-pill); background: rgba(99,178,175,0.16); color: #2c6360; }
.rec-tag.alt { background: rgba(20,43,33,0.06); color: var(--ink-soft); }
.rec-title { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: var(--ink); }
.rec-desc { font-size: 0.92rem; color: var(--ink-soft); line-height: 1.5; }
.rec-why { font-size: 0.88rem; color: var(--teal); }
.rec-why strong { font-weight: 600; }
.rec-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 2px; }
.rec-meta span { font-size: 0.72rem; color: var(--ink-soft); background: rgba(20,43,33,0.05); border-radius: var(--radius-pill); padding: 4px 10px; }

/* ── Section spacing helpers ── */
.section-head { margin-bottom: 8px; }
.center { text-align: center; }
.center .lead, .center .btn-row { margin-left: auto; margin-right: auto; }
.center .lead { max-width: 36em; }
.center .btn-row { justify-content: center; }

/* ── Responsive ── */
@media (max-width: 767px) {
  .stat-grid { grid-template-columns: 1fr; }
  .not-grid { grid-template-columns: 1fr; }
  .recipe-grid { grid-template-columns: 1fr; }
}
