/* ============================================================================
   CHARTER · site.css — the documentation-site chrome (not the product UI)
   ========================================================================== */

/* ---------- App layout ---------- */
.layout {
  display: grid;
  grid-template-columns: var(--sidebar-w) minmax(0, 1fr);
  min-height: 100vh;
}

/* ---------- Topbar ---------- */
.topbar {
  position: sticky; top: 0; z-index: var(--z-topbar);
  grid-column: 1 / -1;
  height: var(--topbar-h);
  display: flex; align-items: center; gap: var(--space-4);
  padding: 0 var(--space-5);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  backdrop-filter: saturate(1.4) blur(10px);
  border-bottom: 1px solid var(--border);
}
.topbar__brand { display: flex; align-items: center; gap: var(--space-3); }
.topbar__name  { font-family: var(--font-display); font-weight: 600; font-size: var(--text-md); letter-spacing: var(--tracking-snug); }
.topbar__name small { color: var(--text-subtle); font-family: var(--font-sans); font-weight: 500; font-size: var(--text-xs); margin-left: 6px; }
.topbar__spacer { flex: 1; }
.topbar__search {
  display: flex; align-items: center; gap: var(--space-2);
  width: min(340px, 34vw); height: 36px; padding: 0 var(--space-3);
  color: var(--text-subtle);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-md); font-size: var(--text-sm);
}
.topbar__search { cursor: text; }
.topbar__search kbd {
  margin-left: auto; font-size: 11px; padding: 1px 6px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 5px; color: var(--text-subtle);
}

/* command palette (⌘K) overlay */
.cmd-scrim {
  position: fixed; inset: 0; background: rgba(20,20,16,.5); z-index: var(--z-overlay);
  display: none; align-items: flex-start; justify-content: center; padding: 12vh var(--space-6) var(--space-6);
}
.cmd-scrim.is-open { display: flex; }
.cmd-empty { padding: var(--space-6) var(--space-4); text-align: center; color: var(--text-subtle); font-size: var(--text-sm); }

/* CA logo mark */
.mark {
  width: 30px; height: 30px; border-radius: 6px; overflow: hidden;
  box-shadow: var(--shadow-xs); flex: none; display: block;
}
.mark img { width: 100%; height: 100%; display: block; }
.mark--lg { width: 44px; height: 44px; border-radius: 8px; }

.iconbtn {
  width: 36px; height: 36px; border-radius: var(--radius-md);
  display: grid; place-items: center; color: var(--text-muted);
  border: 1px solid transparent; transition: background var(--dur) var(--ease), color var(--dur);
}
.iconbtn:hover { background: var(--surface-2); color: var(--text); }

/* ---------- Sidebar ---------- */
.sidebar {
  position: sticky; top: var(--topbar-h);
  align-self: start;
  height: calc(100vh - var(--topbar-h));
  overflow-y: auto;
  border-right: 1px solid var(--border);
  padding: var(--space-5) var(--space-3) var(--space-12);
  background: var(--surface);
}
.nav-group { margin-bottom: var(--space-5); }
.nav-group__label {
  padding: 0 var(--space-3) var(--space-2);
  text-transform: uppercase; letter-spacing: var(--tracking-caps);
  font-size: 11px; font-weight: var(--weight-semibold); color: var(--text-subtle);
}
.nav-link {
  display: flex; align-items: center; gap: var(--space-3);
  padding: 7px var(--space-3); margin-bottom: 1px;
  border-radius: var(--radius-md);
  color: var(--text-muted); font-size: var(--text-base); font-weight: 500;
  transition: background var(--dur) var(--ease), color var(--dur);
}
.nav-link [data-lucide] { width: 16px; height: 16px; color: var(--text-subtle); }
.nav-link:hover { background: var(--surface-2); color: var(--text); text-decoration: none; }
.nav-link:hover [data-lucide] { color: var(--text-muted); }
.nav-link.is-active { background: var(--accent-soft); color: var(--accent-ink); font-weight: 600; }
.nav-link.is-active [data-lucide] { color: var(--accent); }
.nav-link.is-soon { opacity: .55; cursor: default; pointer-events: none; }
.nav-link .soon {
  margin-left: auto; font-size: 10px; font-weight: 600; letter-spacing: .04em;
  color: var(--text-subtle); background: var(--surface-2);
  border: 1px solid var(--border); border-radius: 999px; padding: 1px 6px;
}

/* ---------- Content ---------- */
.content { padding: var(--space-10) var(--space-12) var(--space-20); min-width: 0; }
.content__inner { max-width: var(--content-max); margin: 0 auto; }

.page-head { margin-bottom: var(--space-10); }
.eyebrow {
  text-transform: uppercase; letter-spacing: var(--tracking-caps);
  font-size: var(--text-xs); font-weight: 600; color: var(--brand);
  margin-bottom: var(--space-3);
}
.page-title { font-size: var(--text-3xl); letter-spacing: var(--tracking-tight); }
.page-lede {
  margin-top: var(--space-4); font-size: var(--text-lg);
  line-height: var(--leading-relaxed); color: var(--text-muted); max-width: 60ch;
}
.page-meta { margin-top: var(--space-5); display: flex; gap: var(--space-2); flex-wrap: wrap; }
.metachip {
  font-size: var(--text-xs); color: var(--text-muted);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-pill); padding: 3px 10px; font-weight: 500;
}

.section { margin-top: var(--space-12); }
.section > h2 { font-size: var(--text-xl); letter-spacing: var(--tracking-snug); scroll-margin-top: 80px; }
.section > .section-sub { color: var(--text-muted); margin-top: var(--space-2); margin-bottom: var(--space-5); max-width: 62ch; }
.section-divider { height: 1px; background: var(--border); margin: var(--space-12) 0; }

.prose p { color: var(--text-muted); margin-top: var(--space-3); max-width: 64ch; }
.prose strong { color: var(--text); font-weight: 600; }

/* ---------- Specimen (live example frame) ---------- */
.specimen { border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; margin-top: var(--space-5); background: var(--surface); box-shadow: var(--shadow-xs); }
.specimen__bar {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--border);
  background: var(--surface-2); color: var(--text-subtle); font-size: var(--text-xs);
}
.specimen__bar .dot3 { display: flex; gap: 5px; }
.specimen__bar .dot3 i { width: 9px; height: 9px; border-radius: 99px; background: var(--border-strong); }
.specimen__title { font-weight: 600; color: var(--text-muted); }
.specimen__preview {
  padding: var(--space-10) var(--space-8);
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-5);
  background-color: var(--surface);
  background-image: radial-gradient(var(--border) 1px, transparent 1px);
  background-size: 18px 18px; background-position: -9px -9px;
}
.specimen__preview.is-plain { background-image: none; }
.specimen__preview.is-stack { flex-direction: column; align-items: flex-start; }
.specimen__preview.is-center { justify-content: center; }
.specimen__preview.is-pad-lg { padding: var(--space-12) var(--space-8); }

/* ---------- Code block ---------- */
.code {
  position: relative;
  background: #15160F; color: #E7E7DD;
  font-family: var(--font-mono); font-size: var(--text-sm); line-height: 1.7;
  padding: var(--space-4) var(--space-5); overflow-x: auto;
  border-top: 1px solid var(--border);
}
:root[data-theme="dark"] .code { background: #0E0F09; }
.code .tok-tag { color: #7FCBA3; }
.code .tok-attr { color: #E0B864; }
.code .tok-str { color: #8FB6E0; }
.code .tok-com { color: #6E6F63; font-style: italic; }
.copybtn {
  position: absolute; top: 8px; right: 8px;
  display: flex; align-items: center; gap: 6px;
  font-family: var(--font-sans); font-size: 11px; font-weight: 600;
  color: #cfcfc4; background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12); border-radius: 6px; padding: 4px 8px;
}
.copybtn:hover { background: rgba(255,255,255,.14); color: #fff; }
.copybtn [data-lucide] { width: 13px; height: 13px; }

/* ---------- Token / spec tables ---------- */
.spec-table { width: 100%; border-collapse: collapse; margin-top: var(--space-5); font-size: var(--text-sm); }
.spec-table th { text-align: left; font-weight: 600; color: var(--text-subtle); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); padding: var(--space-2) var(--space-3); border-bottom: 1px solid var(--border-strong); }
.spec-table td { padding: var(--space-3); border-bottom: 1px solid var(--border); vertical-align: middle; }
.spec-table tr:hover td { background: var(--surface-2); }
.spec-table code { background: var(--surface-2); border: 1px solid var(--border); border-radius: 5px; padding: 1px 6px; color: var(--text); }
.spec-table .num { font-family: var(--font-mono); color: var(--text-muted); }

/* ---------- Swatches ---------- */
.swatch-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--space-3); margin-top: var(--space-5); }
.swatch { border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden; background: var(--surface); }
.swatch__chip { height: 72px; }
.swatch__meta { padding: var(--space-3); }
.swatch__name { font-weight: 600; font-size: var(--text-sm); }
.swatch__hex { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-subtle); margin-top: 2px; text-transform: uppercase; }

.ramp { display: flex; border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--border); margin-top: var(--space-4); }
.ramp__step { flex: 1; height: 64px; display: flex; align-items: flex-end; justify-content: center; padding-bottom: 6px; font-family: var(--font-mono); font-size: 10px; }

/* ---------- Spacing / radius / elevation specimens ---------- */
.space-row { display: flex; align-items: center; gap: var(--space-4); padding: 6px 0; }
.space-row__bar { height: 16px; background: var(--green-300); border-radius: 4px; }
.space-row__label { width: 130px; font-size: var(--text-sm); }
.space-row__num { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-subtle); }

.tile-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: var(--space-4); margin-top: var(--space-5); }
.tile { border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); background: var(--surface); }
.tile__demo { height: 64px; background: var(--surface-2); border: 1px solid var(--border); margin-bottom: var(--space-3); }
.tile__demo.is-elev { background: var(--surface); border: none; }
.tile__name { font-weight: 600; font-size: var(--text-sm); }
.tile__val { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-subtle); }

/* ---------- Icon grid ---------- */
.icon-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px,1fr)); gap: var(--space-2); margin-top: var(--space-5); }
.icon-cell { display: flex; flex-direction: column; align-items: center; gap: var(--space-3); padding: var(--space-5) var(--space-2); border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface); transition: border-color var(--dur), background var(--dur); }
.icon-cell:hover { border-color: var(--border-strong); background: var(--surface-2); }
.icon-cell [data-lucide] { width: 22px; height: 22px; color: var(--text); }
.icon-cell span { font-family: var(--font-mono); font-size: 11px; color: var(--text-subtle); }

/* ---------- Callout ---------- */
.callout { display: flex; gap: var(--space-3); padding: var(--space-4) var(--space-5); border-radius: var(--radius-lg); background: var(--info-soft); border: 1px solid color-mix(in srgb, var(--info) 26%, transparent); margin-top: var(--space-6); font-size: var(--text-base); color: var(--text); }
.callout [data-lucide] { color: var(--info-ink); width: 18px; height: 18px; margin-top: 2px; }
.callout b { color: var(--info-ink); }
.callout--ai { background: var(--ai-soft); border-color: color-mix(in srgb, var(--ai) 30%, transparent); }
.callout--ai [data-lucide], .callout--ai b { color: var(--ai-ink); }

/* ---------- Overview cards ---------- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(248px,1fr)); gap: var(--space-4); margin-top: var(--space-6); }
.docs-card { display: block; padding: var(--space-5); border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--surface); transition: border-color var(--dur), box-shadow var(--dur), transform var(--dur); }
.docs-card:hover { border-color: var(--border-strong); box-shadow: var(--shadow-md); transform: translateY(-2px); text-decoration: none; }
.docs-card__icon { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; background: var(--accent-soft); color: var(--accent-ink); margin-bottom: var(--space-4); }
.docs-card__icon [data-lucide] { width: 19px; height: 19px; }
.docs-card h3 { font-size: var(--text-md); font-family: var(--font-sans); font-weight: 600; }
.docs-card p { font-size: var(--text-sm); color: var(--text-muted); margin-top: var(--space-2); line-height: var(--leading-snug); }

/* ---------- Overview index ---------- */
.ov-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-6) var(--space-8); margin-top: var(--space-6); padding: var(--space-5) 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
@media (max-width: 760px) { .ov-stats { grid-template-columns: repeat(2, 1fr); } }
.ov-stat { font-size: var(--text-sm); color: var(--text-muted); }
.ov-stat b { display: block; font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 600; color: var(--text); line-height: 1; margin-bottom: 5px; }
.idx-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(236px, 1fr)); gap: var(--space-3); margin-top: var(--space-4); }
.idx-card { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--surface); transition: border-color var(--dur), box-shadow var(--dur), transform var(--dur); }
.idx-card:hover { border-color: var(--border-strong); box-shadow: var(--shadow-sm); transform: translateY(-1px); text-decoration: none; }
.idx-card.is-soon { opacity: .55; pointer-events: none; }
.idx-card__icon { width: 34px; height: 34px; border-radius: 9px; background: var(--surface-2); color: var(--text-muted); display: grid; place-items: center; flex: none; }
.idx-card__icon [data-lucide] { width: 17px; height: 17px; }
.idx-card__body { min-width: 0; }
.idx-card__t { display: block; font-weight: 600; font-size: var(--text-base); color: var(--text); }
.idx-card__d { display: block; font-size: var(--text-xs); color: var(--text-subtle); margin-top: 2px; }
.idx-card .soon { margin-left: auto; font-size: 10px; font-weight: 600; letter-spacing: .04em; color: var(--text-subtle); background: var(--surface-2); border: 1px solid var(--border); border-radius: 999px; padding: 1px 6px; align-self: center; }

/* ---------- Mobile nav chrome (hidden on desktop) ---------- */
.nav-toggle { display: none; margin-right: calc(var(--space-2) * -1); }
.topbar__search-btn { display: none; }
.nav-scrim {
  position: fixed; inset: var(--topbar-h) 0 0 0;
  z-index: var(--z-sidebar);
  background: rgba(20, 20, 16, .45);
  opacity: 0; visibility: hidden;
  transition: opacity var(--dur) var(--ease), visibility var(--dur);
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .layout { grid-template-columns: 1fr; }
  .content { padding: var(--space-6) var(--space-5) var(--space-16); }

  /* full search pill out; compact search icon button in */
  .topbar__search { display: none; }
  .topbar__search-btn { display: grid; }
  .nav-toggle { display: grid; }
  .topbar__name small { display: none; }     /* reclaim width on narrow screens */

  /* sidebar becomes an off-canvas drawer under the (sticky) topbar.
     Pin top+left and give it an explicit viewport height (dvh so the mobile
     URL bar doesn't cut it off) — NOT height:auto, which sizes to content and
     kills scrolling. overflow-y:auto comes from the base rule; keep it explicit
     plus overscroll containment so the drawer scrolls without moving the page. */
  .sidebar {
    position: fixed; top: var(--topbar-h); left: 0; bottom: auto;
    width: min(86vw, 320px);
    height: calc(100vh - var(--topbar-h));
    height: calc(100dvh - var(--topbar-h));
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    z-index: calc(var(--z-sidebar) + 1);
    transform: translateX(-100%);
    transition: transform var(--dur-slow) var(--ease);
    box-shadow: var(--shadow-lg);
  }
  [data-nav-open] .sidebar { transform: translateX(0); }
  [data-nav-open] .nav-scrim { opacity: 1; visibility: visible; }
}
