/* ============================================================
   KFOO AI — Legal document pages
   Editorial layout: side TOC + prose article + status banners
   Depends on tokens.css
   ============================================================ */

/* ===== Status banner ===== */
.draft-banner {
  background: var(--c-amber-faint);
  border-bottom: 1px solid rgba(177,122,42,0.30);
  padding: var(--s-3) 0;
}
.draft-banner__inner {
  display: flex; align-items: center; gap: var(--s-3); flex-wrap: wrap;
  font-size: var(--t-small); color: var(--c-amber); font-weight: 700;
}
.draft-banner__inner::before {
  content: ""; flex: none; width: 10px; height: 10px; border-radius: 50%;
  background: var(--c-amber); box-shadow: 0 0 0 4px var(--c-amber-faint);
}
.draft-banner__inner small {
  font-weight: 400; color: var(--c-ink-mute); font-family: var(--font-en); letter-spacing: var(--tr-wide); text-transform: uppercase; font-size: 0.6875rem;
}

/* ===== Doc hero ===== */
.doc-hero {
  padding: var(--s-9) 0 var(--s-7);
  border-bottom: 1px solid var(--c-ink-hair);
  background: linear-gradient(180deg, var(--c-beige-soft) 0%, var(--c-beige-light) 100%);
}
.doc-hero__crumbs {
  display: inline-flex; gap: var(--s-2); font-size: var(--t-micro);
  color: var(--c-ink-mute); font-family: var(--font-en);
  letter-spacing: var(--tr-wide); text-transform: uppercase;
  margin-bottom: var(--s-5);
}
.doc-hero__crumbs a { color: var(--c-ink-mute); text-decoration: none; transition: color var(--d-fast) ease; }
.doc-hero__crumbs a:hover { color: var(--c-navy); }
.doc-hero__crumbs span { color: var(--c-ink-faint); }

.doc-hero h1 {
  font-size: var(--t-display); line-height: 1.05;
  font-weight: 800; letter-spacing: var(--tr-tight);
  margin: 0 0 var(--s-4); max-width: 18ch;
}
.doc-hero .accent {
  display: inline-block; position: relative;
}
.doc-hero .accent::after {
  content: ""; display: block; width: 56px; height: 4px;
  background: var(--c-sage); margin-top: var(--s-3); border-radius: var(--r-pill);
}
.doc-hero p.lead {
  font-size: var(--t-lead); color: var(--c-ink-soft);
  max-width: 56ch; line-height: var(--lh-base); margin: 0 0 var(--s-6);
}

.doc-meta {
  display: flex; flex-wrap: wrap; gap: var(--s-5);
  padding-top: var(--s-5); border-top: 1px dashed var(--c-ink-hair);
  margin-top: var(--s-6);
}
.doc-meta__item {
  font-size: var(--t-small);
}
.doc-meta__item b {
  display: block; font-family: var(--font-en); font-size: var(--t-micro);
  letter-spacing: var(--tr-extra); text-transform: uppercase; color: var(--c-ink-mute);
  font-weight: 700; margin-bottom: var(--s-1);
}
.doc-meta__item span { color: var(--c-ink); font-weight: 700; }
.doc-meta__item code {
  font-family: var(--font-mono); font-size: var(--t-small);
  background: var(--c-white); padding: 2px 8px; border-radius: var(--r-xs);
  border: 1px solid var(--c-ink-hair);
}

/* ===== Doc shell: side TOC + article ===== */
.doc-shell {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: var(--s-8);
  padding: var(--s-9) 0;
  align-items: flex-start;
}
@media (max-width: 980px) { .doc-shell { grid-template-columns: 1fr; gap: var(--s-6); } }

.doc-toc {
  position: sticky; top: 88px;
  background: var(--c-white);
  border: 1px solid var(--c-ink-hair);
  border-radius: var(--r-lg);
  padding: var(--s-5);
  max-height: calc(100vh - 120px);
  overflow-y: auto;
}
@media (max-width: 980px) {
  .doc-toc { position: static; max-height: none; }
}
.doc-toc h4 {
  font-family: var(--font-en); font-size: var(--t-micro);
  letter-spacing: var(--tr-extra); text-transform: uppercase; font-weight: 700;
  color: var(--c-ink-mute); margin: 0 0 var(--s-4);
  padding-bottom: var(--s-3); border-bottom: 1px solid var(--c-ink-hair);
}
.doc-toc ol {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--s-1);
  counter-reset: toc;
}
.doc-toc li { counter-increment: toc; }
.doc-toc a {
  display: flex; gap: var(--s-3); align-items: baseline;
  font-size: var(--t-small); color: var(--c-ink-soft); text-decoration: none;
  padding: 0.5rem 0; line-height: 1.4;
  border-inline-start: 2px solid transparent;
  padding-inline-start: var(--s-3); margin-inline-start: -2px;
  transition: color var(--d-fast) ease, border-color var(--d-fast) ease;
}
.doc-toc a::before {
  content: counter(toc, decimal-leading-zero);
  font-family: var(--font-en); font-size: 0.625rem; font-weight: 700;
  color: var(--c-ink-faint); letter-spacing: var(--tr-wide); flex: none;
  min-width: 18px;
}
.doc-toc a:hover, .doc-toc a.is-active {
  color: var(--c-navy); border-inline-start-color: var(--c-sage);
}
.doc-toc a:hover::before, .doc-toc a.is-active::before { color: var(--c-sage); }

/* ===== Article prose ===== */
.doc-article {
  max-width: var(--container-prose);
}
.doc-article > section {
  padding-block: var(--s-7);
  border-bottom: 1px solid var(--c-ink-hair);
  scroll-margin-top: 88px;
}
.doc-article > section:first-child { padding-top: 0; }
.doc-article > section:last-child { border-bottom: none; }

.doc-article h2 {
  font-size: var(--t-h1); line-height: var(--lh-snug);
  font-weight: 800; letter-spacing: var(--tr-tight);
  margin: 0 0 var(--s-5);
  display: flex; flex-direction: column; gap: var(--s-2);
}
.doc-article h2 .num {
  font-family: var(--font-en); font-size: 0.6875rem;
  letter-spacing: var(--tr-extra); text-transform: uppercase;
  color: var(--c-sage); font-weight: 700;
}
.doc-article h3 {
  font-size: var(--t-h2); font-weight: 800; letter-spacing: var(--tr-tight);
  margin: var(--s-6) 0 var(--s-3); line-height: var(--lh-snug);
}
.doc-article p {
  font-size: var(--t-body); line-height: var(--lh-prose);
  margin: 0 0 var(--s-4); color: var(--c-ink);
}
.doc-article p strong { font-weight: 700; color: var(--c-navy); }
.doc-article p em { font-style: italic; }
.doc-article a { color: var(--c-navy); text-decoration: underline; text-decoration-color: var(--c-sage); text-underline-offset: 4px; text-decoration-thickness: 2px; }
.doc-article a:hover { text-decoration-color: var(--c-navy); }
.doc-article ol, .doc-article ul {
  margin: 0 0 var(--s-5); padding-inline-start: var(--s-5);
}
.doc-article ol li, .doc-article ul li {
  padding: var(--s-2) 0; line-height: var(--lh-prose); padding-inline-start: var(--s-3);
}
.doc-article ol { counter-reset: olist; list-style: none; padding-inline-start: 0; }
.doc-article ol > li { counter-increment: olist; position: relative; padding-inline-start: 2.75rem; }
.doc-article ol > li::before {
  content: counter(olist, arabic-indic) ".";
  position: absolute; inset-inline-start: 0; top: var(--s-2);
  font-weight: 800; color: var(--c-sage); font-size: var(--t-body);
  width: 2rem; text-align: start;
}
.doc-article ul { list-style: none; padding-inline-start: 0; }
.doc-article ul > li { position: relative; padding-inline-start: 1.5rem; }
.doc-article ul > li::before {
  content: ""; position: absolute; inset-inline-start: 0; top: 1.1em;
  width: 6px; height: 6px; border-radius: 50%; background: var(--c-sage);
}

.doc-article blockquote {
  border-inline-start: 4px solid var(--c-sage);
  padding: var(--s-2) var(--s-5);
  margin: var(--s-5) 0;
  font-size: var(--t-lead); font-weight: 700; color: var(--c-navy);
  line-height: var(--lh-snug); letter-spacing: var(--tr-tight);
}
.doc-article blockquote em { color: var(--c-ink); font-weight: 400; font-style: normal; line-height: var(--lh-prose); display: block; font-size: var(--t-body); }

/* Call-out box: legal warning / pull quote with body */
.callout {
  background: var(--c-beige-soft);
  border-inline-start: 4px solid var(--c-navy);
  border-radius: var(--r-md);
  padding: var(--s-5) var(--s-6);
  margin: var(--s-5) 0;
}
.callout--warn { border-inline-start-color: var(--c-amber); background: rgba(177,122,42,0.06); }
.callout--sage { border-inline-start-color: var(--c-sage); background: var(--c-sage-faint); }
.callout h4 {
  margin: 0 0 var(--s-2); font-size: var(--t-body); font-weight: 800;
  letter-spacing: var(--tr-tight); color: var(--c-navy);
  display: flex; align-items: center; gap: var(--s-3);
}
.callout p { margin: 0 0 var(--s-2); font-size: var(--t-small); line-height: var(--lh-prose); color: var(--c-ink-soft); }
.callout p:last-child { margin-bottom: 0; }

/* Data table */
.doc-article table {
  width: 100%; border-collapse: collapse;
  margin: var(--s-5) 0; font-size: var(--t-small);
  border-radius: var(--r-md); overflow: hidden;
  box-shadow: var(--e-1);
  background: var(--c-white);
}
.doc-article thead { background: var(--c-navy); color: var(--c-beige); }
.doc-article th, .doc-article td {
  padding: var(--s-4) var(--s-5); text-align: start; line-height: var(--lh-base);
  border-bottom: 1px solid var(--c-ink-hair);
  vertical-align: top;
}
.doc-article th {
  font-weight: 700; font-size: var(--t-micro);
  letter-spacing: var(--tr-wide); text-transform: uppercase;
  border-bottom: 0;
}
.doc-article tr:last-child td { border-bottom: 0; }
.doc-article tbody tr:nth-child(even) { background: var(--c-beige-soft); }

.doc-article code {
  font-family: var(--font-mono); font-size: 0.9em;
  background: var(--c-beige-soft); padding: 2px 6px;
  border-radius: var(--r-xs); border: 1px solid var(--c-ink-hair);
  color: var(--c-navy);
}

/* ===== Cross-link strip at bottom ===== */
.doc-related {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4);
  padding: var(--s-8) 0; max-width: var(--container-prose);
}
@media (max-width: 720px) { .doc-related { grid-template-columns: 1fr; } }
.doc-related a {
  display: block;
  padding: var(--s-5); background: var(--c-white);
  border: 1px solid var(--c-ink-hair); border-radius: var(--r-md);
  text-decoration: none; color: var(--c-ink);
  transition: transform var(--d-base) var(--ease-soft), border-color var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out);
}
.doc-related a:hover { transform: translateY(-3px); border-color: var(--c-sage); box-shadow: var(--e-2); }
.doc-related a small {
  display: block;
  font-family: var(--font-en); font-size: var(--t-micro);
  letter-spacing: var(--tr-extra); text-transform: uppercase;
  color: var(--c-sage); font-weight: 700; margin-bottom: var(--s-2);
}
.doc-related a b { font-size: var(--t-body); font-weight: 800; letter-spacing: var(--tr-tight); }
.doc-related a p { margin: var(--s-2) 0 0; font-size: var(--t-small); color: var(--c-ink-soft); line-height: var(--lh-base); }
