/* =========================================================================
   OCI Observability Atlas — guide.css
   Built on the Oracle Redwood Design System tokens (assets/redwood/).
   References semantic Redwood variables only — no raw hex except level
   accents drawn from the Redwood core palette.
   ========================================================================= */

:root {
  /* Level accents — drawn from the Redwood core palette.
     L0 Pine (Tech·OCI family) · L1 Deep blue · L2 Ochre · L3 Redwood red */
  --l0: var(--pine);
  --l1: var(--blue-deep);
  --l2: var(--ochre);
  --l3: var(--red-redwood);
  --l4: var(--plum-core);
  --l5: var(--ocean);
  --l0-tint: var(--sage-tint);
  --l1-tint: var(--blue-tint);
  --l2-tint: var(--gold-tint);
  --l3-tint: var(--red-tint);
  --l4-tint: var(--plum-tint);
  --l5-tint: #DCE6EE;
}

/* ---------- Layout primitives ---------- */
.wrap { width: min(100% - 2.5rem, var(--container-max)); margin-inline: auto; }
.eyebrow {
  font-family: var(--font-body); font-size: var(--text-2xs); font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-brand);
}
.section { position: relative; z-index: 1; padding-block: var(--space-9); }
.section--sunken { background: var(--surface-sunken); border-block: 1px solid var(--border-subtle); }
.section__head { max-width: 62ch; margin-bottom: var(--space-7); }
.section__head h2 { font-size: var(--text-3xl); margin: var(--space-2) 0 0; }
.section__head p { color: var(--text-muted); margin-top: var(--space-3); font-size: var(--text-md); }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
html { scroll-behavior: smooth; }
body { overflow-x: hidden; }
body.no-scroll { overflow: hidden; }
.lucide { width: 1em; height: 1em; display: inline-block; vertical-align: -0.125em; stroke-width: 2; }

/* ---------- Brand texture atmosphere ---------- */
.texture-corner {
  position: fixed; top: 0; right: 0; width: clamp(220px, 30vw, 460px); z-index: 0;
  opacity: .5; pointer-events: none; mix-blend-mode: multiply;
}

/* ---------- Scroll progress ---------- */
.scrollbar { position: fixed; top: 0; left: 0; height: 3px; width: 0%; z-index: 60;
  background: var(--red-redwood); transition: width 80ms linear; }

/* ---------- Top nav ---------- */
.topnav {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--stone-50) 86%, transparent);
  backdrop-filter: blur(12px); border-bottom: 1px solid var(--border-subtle);
}
.topnav__row { display: flex; align-items: center; gap: var(--space-5); height: 64px; }
.brand { display: flex; align-items: center; gap: var(--space-3); text-decoration: none; }
.brand:hover { text-decoration: none; }
.brand__logo { height: 44px; width: auto; border-radius: 8px; display: block; }
.brand__octo { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 600; color: var(--blue-deep); letter-spacing: .02em; }
.brand__div { width: 1px; height: 22px; background: var(--border-default); }
.brand__name { font-family: var(--font-display); font-size: var(--text-md); color: var(--text-strong); letter-spacing: var(--tracking-snug); }
@media (max-width: 520px) { .brand__name, .brand__div { display: none; } }
.topnav__spacer { flex: 1; }
.levelnav { display: flex; gap: var(--space-1); }
.levelnav a {
  font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--text-muted); text-decoration: none;
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-pill);
  display: inline-flex; align-items: center; gap: var(--space-2);
  transition: background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard);
}
.levelnav a:hover { background: var(--surface-sunken); color: var(--text-strong); text-decoration: none; }
.levelnav a.active { color: var(--text-strong); }
.levelnav a .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lv, var(--stone-400)); flex: none; }
.btn {
  font-family: var(--font-body); font-size: var(--text-sm); font-weight: var(--weight-semibold);
  border: none; cursor: pointer; padding: var(--space-2) var(--space-4); border-radius: var(--radius-pill);
  display: inline-flex; align-items: center; gap: var(--space-2); text-decoration: none;
  transition: background var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-standard);
}
.btn:hover { text-decoration: none; }
.btn--primary { background: var(--action-primary); color: var(--white); }
.btn--primary:hover { background: var(--action-primary-hover); color: var(--white); }
.btn--primary:active { background: var(--action-primary-active); transform: translateY(.5px); }
.btn--secondary { background: transparent; color: var(--action-secondary); box-shadow: inset 0 0 0 1.5px var(--action-secondary); }
.btn--secondary:hover { background: var(--surface-sunken); }
@media (max-width: 920px) { .levelnav { display: none; } }

/* ---------- Hero ---------- */
.hero { position: relative; z-index: 1; padding: var(--space-9) 0 var(--space-8); }
.hero__grid { display: grid; grid-template-columns: 1.55fr 1fr; gap: clamp(2rem, 1rem + 4vw, 5rem); align-items: center; }
@media (max-width: 940px) { .hero__grid { grid-template-columns: 1fr; } }
.hero h1 {
  font-size: clamp(2.6rem, 1.4rem + 4.5vw, var(--text-6xl)); line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight); font-weight: var(--weight-regular); margin: var(--space-4) 0 0;
}
.hero h1 .accent { color: var(--red-redwood); }
.hero__lede { margin-top: var(--space-5); font-size: var(--text-lg); color: var(--text-muted); max-width: 46ch; line-height: var(--leading-relaxed); }
.hero__note { margin-top: var(--space-4); display: flex; align-items: flex-start; gap: var(--space-2); font-size: var(--text-sm); line-height: 1.55; color: var(--text-muted); background: var(--gold-tint); border: 1px solid color-mix(in srgb, var(--ochre) 35%, transparent); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); max-width: 56ch; width: fit-content; }
.hero__note .lucide { color: var(--ochre); flex: none; margin-top: 1px; }
.hero__note b { color: var(--text-strong); font-weight: var(--weight-semibold); }
.hero__actions { margin-top: var(--space-6); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hero__panel {
  position: relative; border-radius: var(--radius-xl); overflow: hidden; min-height: 380px;
  background: var(--surface-inverse); box-shadow: var(--shadow-lg); display: flex; flex-direction: column; justify-content: flex-end;
  padding: clamp(1.5rem, 1rem + 1.4vw, 2.25rem);
}
.hero__panel-bg { position: absolute; inset: 0; background-size: cover; background-position: right center; }
.hero__panel-scrim { position: absolute; inset: 0; background:
  linear-gradient(102deg, rgba(26,24,23,.95) 0%, rgba(26,24,23,.9) 38%, rgba(26,24,23,.55) 68%, rgba(26,24,23,.22) 100%),
  linear-gradient(180deg, rgba(26,24,23,0) 32%, rgba(26,24,23,.55) 100%); }
.hero__panel-body { position: relative; z-index: 1; max-width: 32rem; }
.hero__panel h2 { color: var(--white); font-size: var(--text-xl); margin: 0 0 var(--space-4); letter-spacing: -.01em; }
.hero__qs { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.hero__qs li { color: var(--stone-200); font-size: var(--text-sm); line-height: 1.5; display: flex; gap: var(--space-2); align-items: flex-start; }
.hero__qs li b { color: var(--white); font-weight: var(--weight-semibold); }
.hero__qs .lucide { color: var(--gold-core); flex: none; width: 16px; height: 16px; margin-top: 2px; }

.hero__meta { margin-top: var(--space-7); display: grid; grid-template-columns: repeat(4, auto); gap: var(--space-5) var(--space-7);
  padding-top: var(--space-5); border-top: 1px solid var(--border-subtle); width: fit-content; }
@media (max-width: 560px) { .hero__meta { grid-template-columns: 1fr 1fr; } }
.hero__stat .n { font-family: var(--font-display); font-size: var(--text-3xl); color: var(--text-strong); display: block; line-height: 1; }
.hero__stat .l { font-size: var(--text-xs); color: var(--text-muted); }

/* ---------- Reveal (progressive enhancement) ---------- */
.js .reveal { opacity: 0; transform: translateY(12px); transition: opacity var(--duration-slow) var(--ease-out), transform var(--duration-slow) var(--ease-out); }
.js .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .js .reveal { opacity: 1; transform: none; } }

/* ---------- Steps eyebrow ---------- */
.steptag { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--text-muted); background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-pill);
  padding: var(--space-1) var(--space-3); margin-bottom: var(--space-3); }
.steptag b { color: var(--text-brand); }

/* ---------- Use-case finder ---------- */
.finder { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 900px) { .finder { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .finder { grid-template-columns: 1fr; } }
.uc {
  text-align: left; cursor: pointer; background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-5); font: inherit; color: inherit; position: relative; overflow: hidden;
  transition: transform var(--duration-base) var(--ease-standard), box-shadow var(--duration-base) var(--ease-standard), border-color var(--duration-base) var(--ease-standard);
}
.uc::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 4px; background: var(--action-secondary); transform: scaleY(0); transform-origin: bottom; transition: transform var(--duration-base) var(--ease-emphasized); }
.uc:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.uc:hover::before, .uc[aria-pressed="true"]::before { transform: scaleY(1); }
.uc[aria-pressed="true"] { border-color: var(--action-secondary); box-shadow: var(--shadow-sm); }
.uc__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-3); }
.uc__ic { width: 34px; height: 34px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--blue-tint); color: var(--blue-deep); font-size: 18px; }
.uc__k { font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--text-subtle); letter-spacing: .08em; }
.uc h3 { font-size: var(--text-lg); margin: 0 0 var(--space-2); font-family: var(--font-display); }
.uc p { font-size: var(--text-sm); color: var(--text-muted); margin: 0; }
.uc__tags { margin-top: var(--space-4); display: flex; flex-wrap: wrap; gap: var(--space-1); }
.tag {
  font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: .02em; padding: 2px 8px;
  border-radius: var(--radius-pill); background: var(--surface-sunken); color: var(--text-muted); border: 1px solid var(--border-subtle);
}
.uc--hint { display: flex; align-items: center; border-style: dashed; cursor: default; background: transparent; }
.uc--hint:hover { transform: none; box-shadow: none; }
.uc--hint::before { display: none; }
.uc--hint p { color: var(--text-muted); }

.finder__result {
  margin-top: var(--space-5); border: 1px solid var(--border-default); border-left: 4px solid var(--action-secondary);
  border-radius: var(--radius-lg); padding: var(--space-5) var(--space-6); background: var(--surface-card); display: none; box-shadow: var(--shadow-sm);
}
.finder__result.show { display: block; animation: rise var(--duration-base) var(--ease-out); }
@keyframes rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.finder__result h3 { font-size: var(--text-2xl); margin: var(--space-1) 0 0; }
.finder__detail { color: var(--text-muted); margin: var(--space-3) 0 0; max-width: 70ch; }
.finder__outcomes { list-style: none; margin: var(--space-4) 0 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2) var(--space-5); }
@media (max-width: 680px) { .finder__outcomes { grid-template-columns: 1fr; } }
.finder__outcomes li { display: flex; gap: var(--space-2); align-items: flex-start; font-size: var(--text-sm); color: var(--text-body); }
.finder__outcomes .lucide { color: var(--success); flex: none; font-size: 16px; margin-top: 2px; }
.finder__start { color: var(--text-body); font-weight: var(--weight-semibold); margin: var(--space-5) 0 0; padding: var(--space-3) var(--space-4); background: var(--blue-tint); border-radius: var(--radius-md); border-left: 3px solid var(--action-secondary); }
.path-label { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: .06em; text-transform: uppercase; color: var(--text-subtle); margin: var(--space-5) 0 0; }
.path { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-4); align-items: center; }
.pathchip {
  display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-body); font-size: var(--text-sm);
  font-weight: var(--weight-medium); padding: var(--space-1) var(--space-3); border-radius: var(--radius-pill);
  border: 1px solid var(--brdr, var(--border-default)); cursor: pointer; background: var(--surface-card); color: var(--text-body);
  transition: background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard);
}
.pathchip:hover { background: var(--surface-sunken); border-color: var(--lv); }
.pathchip .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lv); flex: none; }
.path .arrow { color: var(--stone-400); display: inline-flex; }
.finder__foot { margin-top: var(--space-4); font-size: var(--text-sm); color: var(--text-muted); display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.linkbtn { background: none; border: none; color: var(--text-link); cursor: pointer; font: inherit; font-weight: var(--weight-semibold); padding: 0; display: inline-flex; align-items: center; gap: var(--space-1); }
.linkbtn:hover { text-decoration: underline; }

/* ---------- The ladder ---------- */
.ladder { position: relative; }
.ladder::before {
  content: ""; position: absolute; left: clamp(15px, 2.4vw, 28px); top: 10px; bottom: 10px; width: 2px;
  background: linear-gradient(var(--l0), var(--l1), var(--l2), var(--l3), var(--l4)); opacity: .35; border-radius: 2px;
}
.station { position: relative; padding-left: clamp(50px, 6vw, 84px); margin-bottom: var(--space-8); scroll-margin-top: 90px; }
.station__node {
  position: absolute; left: 0; top: 0; width: clamp(32px, 4.8vw, 58px); height: clamp(32px, 4.8vw, 58px);
  border-radius: var(--radius-circle); display: grid; place-items: center; background: var(--surface-card);
  border: 2px solid var(--lvl); color: var(--lvl); font-family: var(--font-display); font-weight: var(--weight-semibold);
  font-size: clamp(.95rem, 2vw, 1.35rem); box-shadow: 0 0 0 6px var(--surface-page);
}
.station__head { display: flex; flex-wrap: wrap; align-items: baseline; gap: var(--space-2) var(--space-4); }
.station__tier { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: .1em; text-transform: uppercase; color: var(--lvl); font-weight: var(--weight-bold); }
.station h3 { font-size: var(--text-2xl); margin: var(--space-1) 0; }
.station__q { color: var(--text-subtle); font-family: var(--font-display); font-style: italic; font-size: var(--text-md); }
.station__body { color: var(--text-muted); max-width: 64ch; margin: var(--space-2) 0 var(--space-5); }

.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(248px, 1fr)); gap: var(--space-4); }
.card {
  text-align: left; cursor: pointer; background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg);
  padding: var(--space-5); font: inherit; color: inherit; position: relative; display: flex; flex-direction: column; gap: var(--space-3);
  transition: transform var(--duration-base) var(--ease-standard), box-shadow var(--duration-base) var(--ease-standard), opacity var(--duration-base) var(--ease-standard);
}
.card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: var(--lvl); border-radius: var(--radius-lg) var(--radius-lg) 0 0; opacity: 0; transition: opacity var(--duration-base) var(--ease-standard); }
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.card:hover::before { opacity: 1; }
.card.dim { opacity: .34; }
.card__top { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-3); }
.card__ic { width: 40px; height: 40px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--lvl-tint); color: var(--lvl); font-size: 21px; flex: none; }
.card h4 { font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-md); letter-spacing: var(--tracking-snug); color: var(--text-strong); margin: 0; }
.card p { font-size: var(--text-sm); color: var(--text-muted); margin: 0; flex: 1; }
.card__foot { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); margin-top: var(--space-1); }
.addon {
  display: inline-flex; align-items: center; gap: var(--space-1); font-family: var(--font-mono); font-size: var(--text-2xs);
  color: var(--success); background: var(--success-tint); padding: 2px 8px; border-radius: var(--radius-pill);
}
.addon .lucide { font-size: 12px; }
.card__more { font-family: var(--font-body); font-size: var(--text-xs); font-weight: var(--weight-semibold); color: var(--text-subtle); display: inline-flex; align-items: center; gap: var(--space-1); }
.card:hover .card__more { color: var(--lvl); }

/* ---------- Landing Zone band ---------- */
.lzband { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 1rem + 3vw, 4rem); align-items: center; }
@media (max-width: 860px) { .lzband { grid-template-columns: 1fr; } }
.lzband h2 { font-size: var(--text-3xl); }
.steps { list-style: none; padding: 0; margin: var(--space-5) 0 0; counter-reset: s; }
.steps li { position: relative; padding-left: var(--space-7); margin-bottom: var(--space-4); color: var(--text-muted); }
.steps li::before {
  counter-increment: s; content: counter(s); position: absolute; left: 0; top: -2px; width: 30px; height: 30px;
  border-radius: var(--radius-circle); background: var(--action-secondary); color: var(--white); display: grid; place-items: center;
  font-family: var(--font-mono); font-size: var(--text-sm); font-weight: var(--weight-medium);
}
.steps li b { color: var(--text-strong); }
.lzcard { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-xl); padding: var(--space-6); box-shadow: var(--shadow-md); }
.lzcore { border: 1.5px solid var(--action-secondary); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); text-align: center; background: var(--blue-tint); }
.lzcore b { font-family: var(--font-display); color: var(--action-secondary); font-size: var(--text-lg); }
.lzcore span { display: block; font-size: var(--text-xs); color: var(--text-muted); margin-top: 2px; }
.lzplus { text-align: center; color: var(--text-subtle); font-family: var(--font-mono); margin: var(--space-3) 0; font-size: var(--text-sm); display: flex; align-items: center; gap: var(--space-2); justify-content: center; }
.lzaddons { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); }
.lzaddon { border: 1px dashed var(--border-default); border-radius: var(--radius-md); padding: var(--space-2) var(--space-3); font-size: var(--text-sm); display: flex; align-items: center; gap: var(--space-2); background: var(--surface-page); }
.lzaddon .dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }

.lzfig { margin: var(--space-7) 0 0; }
.lzfig img { width: 100%; height: auto; display: block; border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); background: var(--surface-card); box-shadow: var(--shadow-sm); }
.lzfig figcaption { margin-top: var(--space-3); display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-2) var(--space-5); font-size: var(--text-sm); color: var(--text-muted); }
.lzfig__src { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-subtle); }
.lzfig__src a { font-weight: var(--weight-semibold); }

/* ---------- Maturity ---------- */
.matgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
@media (max-width: 860px) { .matgrid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .matgrid { grid-template-columns: 1fr; } }
.matcard { border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-5); background: var(--surface-card); border-top: 3px solid var(--lvl); }
.matcard .lv { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: .1em; color: var(--lvl); text-transform: uppercase; font-weight: var(--weight-bold); }
.matcard h4 { font-family: var(--font-display); font-size: var(--text-xl); margin: var(--space-2) 0 var(--space-2); }
.matcard p { font-size: var(--text-sm); color: var(--text-muted); margin: 0; }
.matcard .map { font-size: var(--text-2xs); color: var(--text-subtle); margin-top: var(--space-3); font-family: var(--font-mono); display: block; }

/* ---------- AI layer: whitepaper triad ---------- */
.triad__quote { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--text-strong); max-width: 30ch; line-height: var(--leading-snug); margin: 0 0 var(--space-6); }
.triad__quote .accent { color: var(--red-redwood); }
.triad { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 820px) { .triad { grid-template-columns: 1fr; } }
.triadcard { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); border-top: 3px solid var(--tc); padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-2); }
.triadcard .role { font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--tc); font-weight: var(--weight-bold); }
.triadcard h3 { font-family: var(--font-display); font-size: var(--text-xl); margin: 0; }
.triadcard p { font-size: var(--text-sm); color: var(--text-muted); margin: 0; flex: 1; }
.triadcard .verb { font-family: var(--font-body); font-size: var(--text-sm); font-weight: var(--weight-bold); color: var(--tc); }

/* loop chips SEE -> JUDGE -> IMPROVE */
.loop { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); margin-top: var(--space-5); }
.loopchip { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-sm); padding: var(--space-2) var(--space-4); border-radius: var(--radius-pill); background: var(--l4-tint); color: var(--plum-core); }
.loop .arrow { color: var(--stone-400); display: inline-flex; }

/* ---------- AI reference-architecture diagram ---------- */
.aiflow { display: flex; align-items: stretch; gap: var(--space-2); }
@media (max-width: 1000px) { .aiflow { flex-direction: column; } .aiflow .aiarrow { transform: rotate(90deg); align-self: center; } }
.aistage { flex: 1 1 0; min-width: 0; background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }
.aistage__h { display: flex; align-items: center; gap: var(--space-2); font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: .1em; text-transform: uppercase; font-weight: var(--weight-bold); color: var(--stagec); margin-bottom: var(--space-1); }
.aistage__h .lucide { font-size: 15px; }
.aistage__sub { font-size: var(--text-2xs); color: var(--text-subtle); margin: -4px 0 var(--space-1); }
.aiarrow { align-self: center; color: var(--stone-400); flex: none; display: inline-flex; }
.dchip { display: inline-flex; align-items: center; gap: var(--space-2); width: 100%; text-align: left; font: inherit; font-size: var(--text-sm); font-weight: var(--weight-medium);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); border: 1px solid var(--border-subtle); background: var(--surface-page); color: var(--text-body); cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard), box-shadow var(--duration-fast) var(--ease-standard); }
button.dchip:hover { border-color: var(--l4); background: var(--surface-card); box-shadow: var(--shadow-xs); }
.dchip .lucide { color: var(--stagec); flex: none; font-size: 16px; }
.dchip--static { cursor: default; color: var(--text-muted); border-style: dashed; }
.dchip--static:hover { border-color: var(--border-subtle); box-shadow: none; background: var(--surface-page); }
.aicap { margin-top: var(--space-4); font-size: var(--text-sm); color: var(--text-muted); display: flex; align-items: center; gap: var(--space-2); }
.aicap .lucide { color: var(--text-subtle); flex: none; }

/* ---------- Agent comparison ---------- */
.agents { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 860px) { .agents { grid-template-columns: 1fr; } }
.agentcard { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); border-top: 3px solid var(--ac); padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-3); }
.agentcard__top { display: flex; align-items: center; gap: var(--space-3); }
.agentcard__ic { width: 38px; height: 38px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--ac-tint); color: var(--ac); font-size: 20px; flex: none; }
.agentcard h3 { font-family: var(--font-display); font-size: var(--text-lg); margin: 0; }
.agentcard .kind { font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: .06em; text-transform: uppercase; color: var(--ac); font-weight: var(--weight-bold); }
.agentcard .use { font-size: var(--text-sm); color: var(--text-body); margin: 0; }
.agentcard dl { margin: 0; display: grid; grid-template-columns: auto 1fr; gap: var(--space-1) var(--space-3); font-size: var(--text-sm); }
.agentcard dt { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-subtle); text-transform: uppercase; letter-spacing: .04em; padding-top: 2px; }
.agentcard dd { margin: 0; color: var(--text-muted); }
.agentcard .best { display: inline-flex; align-items: center; gap: var(--space-1); font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--success); background: var(--success-tint); padding: 2px 8px; border-radius: var(--radius-pill); align-self: flex-start; }

/* ---------- Reference implementation band ---------- */
.refimpl { background: var(--surface-inverse); border-radius: var(--radius-xl); padding: clamp(2rem, 1.5rem + 3vw, 3.5rem); position: relative; overflow: hidden; }
.refimpl__bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: .14; }
.refimpl__in { position: relative; z-index: 1; display: grid; grid-template-columns: 1.5fr 1fr; gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: center; }
@media (max-width: 820px) { .refimpl__in { grid-template-columns: 1fr; } }
.refimpl .eyebrow { color: var(--gold-core); }
.refimpl h2 { color: var(--white); font-size: var(--text-3xl); margin: var(--space-2) 0 var(--space-3); }
.refimpl p { color: var(--stone-200); font-size: var(--text-md); margin: 0 0 var(--space-4); }
.refimpl__tags { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-5); }
.refimpl__tags .tag { background: rgba(255,255,255,.08); color: var(--stone-200); border-color: rgba(255,255,255,.14); }
.refimpl__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.refimpl__side { display: flex; flex-direction: column; gap: var(--space-3); }
.refstat { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-md); padding: var(--space-4); }
.refstat b { font-family: var(--font-display); color: var(--white); font-size: var(--text-xl); display: block; }
.refstat span { color: var(--stone-300); font-size: var(--text-sm); }
.btn--ghostlight { background: transparent; color: var(--white); box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.4); }
.btn--ghostlight:hover { background: rgba(255,255,255,.1); color: var(--white); }

/* ---------- Slide-over inspector (Redwood console pattern) ---------- */
.scrim { position: fixed; inset: 0; z-index: 90; background: rgba(42,47,47,.4); opacity: 0; visibility: hidden;
  transition: opacity var(--duration-base) var(--ease-standard), visibility var(--duration-base); }
.scrim.open { opacity: 1; visibility: visible; }
.inspector {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 91; width: min(540px, 94vw);
  background: var(--surface-card); box-shadow: var(--shadow-xl); transform: translateX(100%);
  transition: transform var(--duration-slow) var(--ease-emphasized); display: flex; flex-direction: column; overflow: hidden;
}
.inspector.open { transform: none; }
.inspector__bar { height: 5px; background: var(--lvl, var(--action-secondary)); flex: none; }
.inspector__head { padding: var(--space-5) var(--space-6) var(--space-4); border-bottom: 1px solid var(--border-subtle); display: flex; gap: var(--space-4); align-items: flex-start; }
.inspector__ic { width: 46px; height: 46px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--lvl-tint, var(--blue-tint)); color: var(--lvl, var(--action-secondary)); font-size: 24px; flex: none; }
.inspector__title { flex: 1; min-width: 0; }
.inspector__title .tier { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: .1em; text-transform: uppercase; color: var(--lvl, var(--action-secondary)); font-weight: var(--weight-bold); }
.inspector__title h3 { font-size: var(--text-2xl); margin: var(--space-1) 0 0; }
.inspector__title p { font-size: var(--text-sm); color: var(--text-muted); margin: var(--space-2) 0 0; }
.iclose { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-circle); width: 36px; height: 36px; cursor: pointer; color: var(--text-muted); flex: none; display: grid; place-items: center; font-size: 18px; transition: background var(--duration-fast) var(--ease-standard); }
.iclose:hover { background: var(--surface-sunken); color: var(--text-strong); }
.inspector__scroll { overflow-y: auto; padding: var(--space-5) var(--space-6) var(--space-8); flex: 1; }

.callout { display: flex; gap: var(--space-3); background: var(--success-tint); border: 1px solid color-mix(in srgb, var(--success) 30%, transparent); border-radius: var(--radius-md); padding: var(--space-4); margin-bottom: var(--space-5); }
.callout .lucide { color: var(--success); flex: none; font-size: 18px; margin-top: 2px; }
.callout b { color: var(--success); }
.callout p { margin: var(--space-1) 0 0; font-size: var(--text-sm); color: var(--text-body); }

.lens { display: flex; gap: var(--space-1); background: var(--surface-sunken); padding: 4px; border-radius: var(--radius-pill); margin-bottom: var(--space-4); }
.lens button { flex: 1; font: inherit; font-size: var(--text-sm); font-weight: var(--weight-semibold); cursor: pointer; border: none; background: none;
  padding: var(--space-2); border-radius: var(--radius-pill); color: var(--text-muted); transition: background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard); }
.lens button[aria-selected="true"] { background: var(--surface-card); color: var(--text-strong); box-shadow: var(--shadow-xs); }
.lenspanel { display: none; }
.lenspanel.active { display: block; animation: rise var(--duration-base) var(--ease-out); }
.lenspanel h4 { font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--text-subtle); margin: 0 0 var(--space-2); }
.lenspanel ul { margin: 0 0 var(--space-4); padding-left: var(--space-5); }
.lenspanel li { margin-bottom: var(--space-2); color: var(--text-body); }
.lenspanel li b { color: var(--text-strong); }

.codeblock { background: var(--stone-900); border-radius: var(--radius-md); overflow: hidden; margin-top: var(--space-2); }
.codeblock__bar { display: flex; align-items: center; justify-content: space-between; padding: var(--space-2) var(--space-3); background: #20262b; }
.codeblock__lang { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--sage-core); letter-spacing: .04em; }
.copybtn { background: none; border: 1px solid #3a4248; color: var(--stone-300); font-family: var(--font-mono); font-size: var(--text-xs); padding: 3px 10px; border-radius: var(--radius-sm); cursor: pointer; display: inline-flex; align-items: center; gap: var(--space-1); transition: background var(--duration-fast) var(--ease-standard); }
.copybtn:hover { background: #3a4248; color: var(--white); }
.copybtn.ok { color: var(--green-core); border-color: var(--green-core); }
.codeblock pre { margin: 0; padding: var(--space-4); overflow-x: auto; }
.codeblock code { font-family: var(--font-mono); font-size: var(--text-sm); line-height: 1.7; color: var(--stone-200); white-space: pre; background: none; padding: 0; }
.codeblock .c { color: var(--stone-500); }
.codeblock .k { color: var(--ochre); }

.idocs { display: inline-flex; align-items: center; gap: var(--space-2); margin-top: var(--space-5); font-size: var(--text-sm); font-weight: var(--weight-semibold); }

/* inspector learn-more */
.ilearn__h { font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--text-subtle); margin: var(--space-6) 0 var(--space-3); padding-top: var(--space-4); border-top: 1px solid var(--border-subtle); }
.ilearn { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.ilearn li { display: flex; flex-direction: column; gap: 2px; }
.ilearn a { font-size: var(--text-sm); font-weight: var(--weight-semibold); display: inline-flex; align-items: center; gap: var(--space-1); }
.ilearn a .lucide { font-size: 13px; color: var(--text-subtle); flex: none; }
.ilearn span { font-size: var(--text-xs); color: var(--text-muted); }

/* ---------- Resources section ---------- */
.reslist { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 920px) { .reslist { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .reslist { grid-template-columns: 1fr; } }
.resgroup { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-5); }
.resgroup h3 { font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--text-brand); margin: 0 0 var(--space-4); }
.resgroup ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-4); }
.resgroup li { display: flex; flex-direction: column; gap: 2px; }
.resgroup a { font-size: var(--text-sm); font-weight: var(--weight-semibold); line-height: var(--leading-snug); display: inline-flex; align-items: baseline; gap: var(--space-1); }
.resgroup a .lucide { font-size: 12px; color: var(--text-subtle); flex: none; align-self: center; }
.resgroup span { font-size: var(--text-xs); color: var(--text-muted); }
.projlabel { display: flex; align-items: center; gap: var(--space-1); font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: .04em; text-transform: uppercase; color: var(--text-subtle); margin: var(--space-4) 0 var(--space-3); padding-top: var(--space-3); border-top: 1px dashed var(--border-subtle); }
.projlabel .lucide { font-size: 13px; }
.resgroup .projlist { gap: var(--space-3); }
.resgroup .projlist a .lucide, .ilearn a .lucide { color: var(--text-body); }

/* ---------- Footer ---------- */
.foot { background: var(--surface-inverse); color: var(--stone-200); padding: var(--space-8) 0 var(--space-6); position: relative; z-index: 1; }
.foot a { color: var(--stone-200); }
.foot a:hover { color: var(--white); }
.foot__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: var(--space-6); }
@media (max-width: 740px) { .foot__grid { grid-template-columns: 1fr; gap: var(--space-5); } }
.foot__logo { height: 76px; width: auto; margin-bottom: var(--space-4); display: block; }
.foot__disclaimer { margin-top: var(--space-7); padding: var(--space-4) var(--space-5); background: rgba(255,255,255,.04); border: 1px solid var(--stone-800); border-radius: var(--radius-md); font-size: var(--text-xs); color: var(--stone-400); line-height: var(--leading-relaxed); }
.foot__disclaimer strong { color: var(--stone-200); }
.foot__lede { font-family: var(--font-display); font-size: var(--text-xl); color: var(--white); max-width: 34ch; line-height: var(--leading-snug); margin: 0; }
.foot h4 { font-family: var(--font-body); font-size: var(--text-2xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--stone-400); font-weight: var(--weight-bold); margin: 0 0 var(--space-4); }
.foot ul { list-style: none; padding: 0; margin: 0; }
.foot li { margin-bottom: var(--space-2); font-size: var(--text-sm); }
.foot__legal { margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid var(--stone-800); font-size: var(--text-xs); color: var(--stone-500); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-3); }

/* ============ Persona + Industry start selector ============ */
.topnav__seg { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--text-muted); text-decoration: none; padding: var(--space-2) var(--space-3); border-radius: var(--radius-pill); transition: background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard); }
.topnav__seg:hover { background: var(--surface-sunken); color: var(--text-strong); text-decoration: none; }
@media (max-width: 1080px) { .topnav__seg { display: none; } }

.start__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
@media (max-width: 760px) { .start__grid { grid-template-columns: 1fr; gap: var(--space-5); } }
.start__label { font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--text-subtle); margin: 0 0 var(--space-3); }
.pickrow { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.pickchip { display: inline-flex; align-items: center; gap: var(--space-2); font: inherit; font-size: var(--text-sm); font-weight: var(--weight-medium); cursor: pointer;
  background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-pill); padding: var(--space-2) var(--space-4); color: var(--text-body);
  transition: border-color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-standard); }
.pickchip:hover { border-color: var(--action-secondary); transform: translateY(-1px); }
.pickchip[aria-pressed="true"] { background: var(--action-secondary); color: var(--white); border-color: var(--action-secondary); }
.pickchip .pic { width: 16px; height: 16px; flex: none; }

.start__result { display: none; margin-top: var(--space-6); border: 1px solid var(--border-default); border-left: 4px solid var(--action-secondary); border-radius: var(--radius-lg); padding: var(--space-5) var(--space-6); background: var(--surface-card); box-shadow: var(--shadow-sm); }
.start__result.show { display: block; animation: rise var(--duration-base) var(--ease-out); }
.start__lead { font-family: var(--font-display); font-size: var(--text-xl); color: var(--text-strong); margin: 0 0 var(--space-3); }
.start__line { color: var(--text-muted); margin: 0 0 var(--space-2); font-size: var(--text-md); }
.start__levels { display: flex; flex-wrap: wrap; gap: var(--space-2); margin: var(--space-4) 0; }
.lvlchip { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-sm); text-decoration: none; padding: var(--space-1) var(--space-3); border-radius: var(--radius-pill); border: 1px solid var(--lv); color: var(--text-body); }
.lvlchip:hover { background: color-mix(in srgb, var(--lv) 10%, transparent); text-decoration: none; }
.lvlchip .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lv); }
.start__svc { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); margin-top: var(--space-2); }
.start__k { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-subtle); text-transform: uppercase; letter-spacing: .04em; }
.start__cta { display: flex; flex-wrap: wrap; gap: var(--space-5); margin-top: var(--space-5); }
.start__cta .pic { width: 16px; height: 16px; }

/* ============ IAM note ============ */
.iam-note { display: flex; gap: var(--space-4); background: var(--blue-tint); border: 1px solid color-mix(in srgb, var(--blue-deep) 30%, transparent); border-radius: var(--radius-lg); padding: var(--space-5); margin-bottom: var(--space-6); }
.iam-note .lucide { width: 26px; height: 26px; color: var(--blue-deep); flex: none; margin-top: 2px; }
.iam-note b { color: var(--text-strong); }
.iam-note p { margin: var(--space-2) 0 0; color: var(--text-body); font-size: var(--text-sm); }

/* ============ Persona cards ============ */
.pgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
@media (max-width: 1080px) { .pgrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .pgrid { grid-template-columns: 1fr; } }
.pcard { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-3); transition: transform var(--duration-base) var(--ease-standard), box-shadow var(--duration-base) var(--ease-standard); }
.pcard:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.pcard__top { display: flex; gap: var(--space-3); align-items: flex-start; }
.pcard__ic { width: 40px; height: 40px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--blue-tint); color: var(--blue-deep); flex: none; }
.pcard__ic .pic { width: 22px; height: 22px; }
.pcard h3 { font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-md); letter-spacing: var(--tracking-snug); color: var(--text-strong); margin: 0; }
.pcard__lens { font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--text-subtle); }
.pcard__sum { font-size: var(--text-sm); color: var(--text-muted); margin: 0; }
.pcard__levels { display: flex; flex-wrap: wrap; gap: var(--space-1); }
.lvltag { font-family: var(--font-mono); font-size: var(--text-2xs); font-weight: var(--weight-bold); color: var(--lv); background: color-mix(in srgb, var(--lv) 12%, transparent); border-radius: var(--radius-sm); padding: 2px 7px; }
.pcard__dl { margin: 0; display: grid; gap: var(--space-1); }
.pcard__dl dt { font-family: var(--font-mono); font-size: var(--text-2xs); text-transform: uppercase; letter-spacing: .04em; color: var(--text-subtle); margin-top: var(--space-2); }
.pcard__dl dd { margin: 0; font-size: var(--text-sm); color: var(--text-body); }
.pcard__svc { display: flex; flex-wrap: wrap; gap: var(--space-1); margin-top: auto; padding-top: var(--space-2); border-top: 1px solid var(--border-subtle); }

/* ============ L5 multitenancy ============ */
.tier3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); margin-top: var(--space-6); }
@media (max-width: 820px) { .tier3 { grid-template-columns: 1fr; } }
.tier3card { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); border-top: 3px solid var(--tc); padding: var(--space-5); }
.tier3card h3 { font-family: var(--font-display); font-size: var(--text-lg); margin: 0 0 var(--space-2); color: var(--tc); }
.tier3card p { font-size: var(--text-sm); color: var(--text-muted); margin: 0; }
.l5scale { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); margin-top: var(--space-6); }
.l5scale__k { font-family: var(--font-mono); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .06em; color: var(--text-subtle); margin-right: var(--space-2); }
.l5pill { display: inline-flex; align-items: center; font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-sm); padding: var(--space-1) var(--space-4); border-radius: var(--radius-pill); background: var(--surface-card); border: 1px solid var(--border-default); color: var(--text-body); }
.l5pill--op { background: var(--l5-tint); border-color: var(--l5); color: var(--l5); }
.l5scale .arrow { color: var(--stone-400); }

/* ingestion recipe gallery (multitenancy) */
.recipes { display: grid; grid-template-columns: repeat(auto-fill, minmax(264px, 1fr)); gap: var(--space-4); }
.recipe { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-2); padding: var(--space-4); background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); text-decoration: none; color: inherit; transition: transform .2s var(--ease-out), box-shadow .2s var(--ease-out), border-color .2s var(--ease-out); }
.recipe:hover, .recipe:focus-visible { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: color-mix(in srgb, var(--ochre) 45%, var(--border-subtle)); outline: none; }
.recipe__dir { font-family: var(--font-mono); font-size: var(--text-2xs); letter-spacing: .04em; text-transform: uppercase; font-weight: 700; padding: 3px 9px; border-radius: var(--radius-pill); }
.recipe__dir--in { color: var(--pine); background: color-mix(in srgb, var(--pine) 13%, transparent); }
.recipe__dir--out { color: var(--plum); background: color-mix(in srgb, var(--plum) 13%, transparent); }
.recipe__dir--build { color: var(--ocean); background: color-mix(in srgb, var(--ocean) 13%, transparent); }
.recipe h4 { margin: 0; font-size: var(--text-md); font-weight: var(--weight-semibold); color: var(--text-strong); line-height: 1.3; }
.recipe p { margin: 0; font-size: var(--text-sm); color: var(--text-muted); flex: 1; line-height: 1.5; }
.recipe__repo { margin-top: var(--space-1); font-family: var(--font-mono); font-size: var(--text-2xs); color: var(--ochre); word-break: break-all; }

/* inspector "relevant to" personas */
.i-personas { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2); margin-bottom: var(--space-4); }
.i-personas:empty { display: none; }
.i-personas__k { font-family: var(--font-mono); font-size: var(--text-2xs); text-transform: uppercase; letter-spacing: .06em; color: var(--text-subtle); }
.ptag { font-size: var(--text-xs); font-weight: var(--weight-semibold); color: var(--text-body); text-decoration: none; background: var(--surface-sunken); border: 1px solid var(--border-subtle); border-radius: var(--radius-pill); padding: 2px 10px; }
.ptag:hover { border-color: var(--action-secondary); color: var(--action-secondary); text-decoration: none; }

/* L5 best practices + references */
.bp5 { list-style: none; counter-reset: bp; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width: 760px) { .bp5 { grid-template-columns: 1fr; } }
.bp5 li { position: relative; padding-left: var(--space-7); color: var(--text-muted); font-size: var(--text-sm); }
.bp5 li b { color: var(--text-strong); }
.bp5 li::before { counter-increment: bp; content: counter(bp); position: absolute; left: 0; top: -2px; width: 30px; height: 30px; border-radius: 50%; background: var(--l5); color: var(--white); display: grid; place-items: center; font-family: var(--font-mono); font-size: var(--text-sm); }
.refrow { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2) var(--space-4); margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid var(--border-subtle); }
.refrow__k { font-family: var(--font-mono); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: .06em; color: var(--text-subtle); }
.refrow a { font-size: var(--text-sm); font-weight: var(--weight-semibold); }
