/* Hallmark · Long Document · soft · green — shared shell for nourish-web */
@import url("./tokens.css");

*, *::before, *::after { box-sizing: border-box; }
html { overflow-x: clip; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { overflow-x: clip; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

body {
  margin: 0;
  background: var(--color-paper);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-body);
  font-feature-settings: "ss01", "cv05";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--color-accent-soft); color: var(--color-ink); }

a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: 4px;
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 560; line-height: var(--leading-snug); }
h1 { letter-spacing: -0.02em; }

.shell { width: 100%; max-width: var(--shell); margin-inline: auto; padding-inline: var(--space-12); }

/* skip link */
.skip {
  position: absolute; left: -999px; top: 0; z-index: 100;
  background: var(--color-accent); color: var(--color-on-accent);
  padding: var(--space-6) var(--space-12); border-radius: 0 0 var(--radius-sm) 0;
}
.skip:focus { left: 0; }

/* ---------- Header ---------- */
.masthead {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklch, var(--color-paper) 86%, transparent);
  backdrop-filter: saturate(1.4) blur(10px);
  border-bottom: 1px solid var(--color-rule);
}
.masthead__row {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-16); min-height: 64px;
}
.brand { display: inline-flex; align-items: center; gap: var(--space-6); color: var(--color-ink); font-weight: 600; }
.brand:hover { text-decoration: none; }
.brand__mark { flex: none; width: 30px; height: 30px; }
.brand__name { font-family: var(--font-display); font-size: 1.32rem; font-weight: 600; letter-spacing: -0.01em; }
.brand__name b { color: var(--color-accent); font-weight: 600; }

.masthead__nav { display: flex; align-items: center; gap: var(--space-6); }
.navlink {
  color: var(--color-ink-2); font-size: var(--text-sm); font-weight: 500;
  padding: var(--space-4) var(--space-8); border-radius: var(--radius-pill);
  white-space: nowrap; transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.navlink:hover { color: var(--color-ink); background: var(--color-paper-3); text-decoration: none; }
.navlink[aria-current="page"] { color: var(--color-accent); background: var(--color-accent-soft); }

/* ---------- Sprout mark animation ---------- */
.brand__mark .leaf { transform-origin: 12px 22px; }

/* ---------- Hero (index) ---------- */
.hero { padding-block: var(--space-48) var(--space-32); }
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-6);
  font-size: var(--text-sm); font-weight: 600; color: var(--color-accent);
  letter-spacing: 0.01em; margin-bottom: var(--space-12);
}
.hero__eyebrow::before { content: ""; width: 22px; height: 1.5px; background: var(--color-accent); display: inline-block; }
.hero h1 { font-size: var(--text-display); margin: 0 0 var(--space-12); max-width: 16ch; overflow-wrap: anywhere; min-width: 0; }
.hero p { font-size: var(--text-lg); color: var(--color-ink-2); max-width: 54ch; margin: 0; }

/* ---------- Doc cards (index) ---------- */
.cards {
  display: grid; gap: var(--space-12);
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  padding-bottom: var(--space-32);
}
.card {
  display: flex; flex-direction: column; gap: var(--space-6);
  background: var(--color-paper-2); border: 1px solid var(--color-rule);
  border-radius: var(--radius-lg); padding: var(--space-16);
  box-shadow: var(--shadow-card);
  transition: transform var(--dur-mid) var(--ease-out), border-color var(--dur-mid) var(--ease-out);
}
.card:hover { transform: translateY(-3px); border-color: var(--color-rule-strong); text-decoration: none; }
.card__kicker { font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-ink-3); }
.card h2 { font-size: var(--text-xl); margin: 0; color: var(--color-ink); }
.card p { margin: 0; color: var(--color-ink-2); font-size: var(--text-sm); }
.card__go { margin-top: auto; padding-top: var(--space-8); color: var(--color-accent); font-weight: 600; font-size: var(--text-sm); display: inline-flex; gap: var(--space-4); align-items: center; }
.card.is-danger { border-color: color-mix(in oklch, var(--color-danger) 30%, var(--color-rule)); }
.card.is-danger .card__kicker, .card.is-danger .card__go { color: var(--color-danger); }

/* contact strip */
.contact {
  margin-block: var(--space-12) var(--space-48);
  background: var(--color-accent-soft);
  border-radius: var(--radius-lg); padding: var(--space-20) var(--space-24);
  display: flex; flex-wrap: wrap; gap: var(--space-12); align-items: center; justify-content: space-between;
}
.contact h2 { font-size: var(--text-xl); margin: 0 0 var(--space-2); }
.contact p { margin: 0; color: var(--color-ink-2); }

/* ---------- Document pages ---------- */
.doc { padding-block: var(--space-32) var(--space-48); }
.doc__head { max-width: var(--measure); margin-bottom: var(--space-24); }
.doc__head h1 { font-size: var(--text-3xl); margin: 0 0 var(--space-8); overflow-wrap: anywhere; min-width: 0; }
.doc__meta { font-size: var(--text-sm); color: var(--color-ink-3); }
.doc__meta b { color: var(--color-ink-2); font-weight: 600; }

.doc__layout { display: grid; gap: var(--space-32); grid-template-columns: 1fr; }
@media (min-width: 880px) { .doc__layout { grid-template-columns: 220px minmax(0, 1fr); } }

/* table of contents */
.toc { align-self: start; position: sticky; top: 88px; font-size: var(--text-sm); }
@media (max-width: 879px) {
  .toc { position: static; border: 1px solid var(--color-rule); border-radius: var(--radius-md); padding: var(--space-12); background: var(--color-paper-2); }
}
.toc__label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-ink-3); font-weight: 600; margin-bottom: var(--space-8); }
.toc ol { list-style: none; margin: 0; padding: 0; counter-reset: toc; display: flex; flex-direction: column; gap: var(--space-2); }
.toc li { counter-increment: toc; }
.toc a { display: block; color: var(--color-ink-2); padding: var(--space-3) var(--space-6); border-radius: var(--radius-sm); border-left: 2px solid transparent; }
.toc a::before { content: counter(toc) "."; color: var(--color-ink-3); margin-right: var(--space-6); font-variant-numeric: tabular-nums; }
.toc a:hover { color: var(--color-ink); background: var(--color-paper-3); text-decoration: none; }

.prose { max-width: var(--measure); }
.prose section { scroll-margin-top: 88px; }
.prose section + section { margin-top: var(--space-32); padding-top: var(--space-24); border-top: 1px solid var(--color-rule); }
.prose h2 {
  font-size: var(--text-2xl); margin: 0 0 var(--space-12);
  display: flex; align-items: baseline; gap: var(--space-8); overflow-wrap: anywhere; min-width: 0;
}
.prose h2 .num { font-family: var(--font-mono); font-size: var(--text-base); color: var(--color-accent); font-weight: 500; flex: none; }
.prose h3 { font-size: var(--text-lg); margin: var(--space-20) 0 var(--space-6); color: var(--color-ink); }
.prose p { margin: 0 0 var(--space-12); color: var(--color-ink); }
.prose ul, .prose ol { margin: 0 0 var(--space-12); padding-left: var(--space-20); color: var(--color-ink); }
.prose li { margin-bottom: var(--space-6); }
.prose li::marker { color: var(--color-accent); }
.prose strong { font-weight: 600; }
.prose a { font-weight: 500; }

/* definition rows */
.rows { border: 1px solid var(--color-rule); border-radius: var(--radius-md); overflow: hidden; margin: 0 0 var(--space-12); background: var(--color-paper-2); }
.rows__item { display: grid; grid-template-columns: 1fr; gap: var(--space-2); padding: var(--space-12) var(--space-16); }
.rows__item + .rows__item { border-top: 1px solid var(--color-rule); }
@media (min-width: 560px) { .rows__item { grid-template-columns: 200px minmax(0, 1fr); gap: var(--space-16); align-items: baseline; } }
.rows__term { font-weight: 600; color: var(--color-ink); }
.rows__desc { color: var(--color-ink-2); font-size: var(--text-sm); }

/* callout */
.callout {
  border-radius: var(--radius-md); padding: var(--space-16) var(--space-20);
  background: var(--color-accent-soft); border: 1px solid color-mix(in oklch, var(--color-accent) 22%, transparent);
  margin: 0 0 var(--space-16);
}
.callout p:last-child { margin-bottom: 0; }
.callout.is-warn { background: var(--color-danger-soft); border-color: color-mix(in oklch, var(--color-danger) 28%, transparent); }
.callout__label { font-weight: 600; color: var(--color-accent); display: block; margin-bottom: var(--space-4); }
.callout.is-warn .callout__label { color: var(--color-danger); }

/* numbered step path (deletion) */
.steps { counter-reset: step; list-style: none; margin: 0 0 var(--space-16); padding: 0; }
.steps > li {
  counter-increment: step; position: relative;
  padding-left: var(--space-48); padding-bottom: var(--space-20);
  border-left: 2px solid var(--color-rule); margin-left: 14px;
}
.steps > li:last-child { border-left-color: transparent; padding-bottom: 0; }
.steps > li::before {
  content: counter(step); position: absolute; left: -16px; top: -4px;
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--color-accent); color: var(--color-on-accent);
  display: grid; place-items: center; font-weight: 600; font-size: var(--text-sm);
  font-family: var(--font-body); font-variant-numeric: tabular-nums;
}
.steps h3 { margin: 0 0 var(--space-4); }

/* primary button */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-6);
  background: var(--color-accent); color: var(--color-on-accent);
  font-family: var(--font-body); font-weight: 600; font-size: var(--text-base);
  padding: var(--space-8) var(--space-16); border-radius: var(--radius-pill);
  border: 1px solid transparent; cursor: pointer; white-space: nowrap;
  transition: transform var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.btn:hover { background: var(--color-accent-press); text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn.is-ghost { background: transparent; color: var(--color-accent); border-color: var(--color-rule-strong); }
.btn.is-ghost:hover { background: var(--color-paper-3); }

/* ---------- Footer ---------- */
.footer { border-top: 1px solid var(--color-rule); margin-top: var(--space-48); background: var(--color-paper-3); }
.footer__row { display: flex; flex-wrap: wrap; gap: var(--space-16) var(--space-24); align-items: center; justify-content: space-between; padding-block: var(--space-24); }
.footer__brand { display: flex; align-items: center; gap: var(--space-6); color: var(--color-ink-2); }
.footer__nav { display: flex; flex-wrap: wrap; gap: var(--space-6) var(--space-16); }
.footer__nav a { color: var(--color-ink-2); font-size: var(--text-sm); }
.footer__nav a:hover { color: var(--color-ink); }
.footer__legal { font-size: var(--text-xs); color: var(--color-ink-3); padding-bottom: var(--space-24); margin: 0; }

@media (max-width: 560px) {
  .masthead__nav { gap: var(--space-2); }
  .navlink { padding: var(--space-4) var(--space-6); }
  .hero { padding-block: var(--space-32) var(--space-24); }
}

/* ---------- About page ---------- */
.section { padding-block: var(--space-32); border-top: 1px solid var(--color-rule); }
.section:first-of-type { border-top: 0; }
.section__label {
  font-size: var(--text-xs); font-weight: 600; letter-spacing: 0.09em;
  text-transform: uppercase; color: var(--color-accent); margin: 0 0 var(--space-12);
}
/* big mission / vision statement */
.statement {
  font-family: var(--font-display); font-weight: 500;
  font-size: var(--text-2xl); line-height: 1.28; letter-spacing: -0.01em;
  color: var(--color-ink); max-width: 24ch; margin: 0;
  overflow-wrap: anywhere; min-width: 0;
}
.statement em { color: var(--color-accent); font-style: italic; }
.duo { display: grid; gap: var(--space-32); grid-template-columns: 1fr; }
@media (min-width: 760px) { .duo { grid-template-columns: 1fr 1fr; } }
.duo .statement { font-size: var(--text-xl); }
/* values grid reuses .cards/.card; tighten the value card */
.value h2 { font-size: var(--text-lg); }
.value p { font-size: var(--text-sm); }
.value__num { font-family: var(--font-mono); color: var(--color-accent); font-size: var(--text-sm); }
