/* ============================================================================
 * figures.css — the shared "scene" figure kit for the solution pages.
 *
 * Lifts the home-page Solutions diagram language (see dist/_strategy-section.html)
 * into a reusable system so every solution-page diagram reads like the home page:
 * depth-shadowed glass panels, a header (title + summary), a status-strip footer,
 * and composed bodies (master/detail lists, mini-gantt timelines, metric strips,
 * registers). One panel background (#0e121b), one accent language.
 *
 * Scope: each figure is `<figure class="fx"> … </figure>`. All tokens live on .fx
 * so the kit is self-contained and collision-free with rd-/hl-/aw-/ais- classes.
 * ============================================================================ */

.fx{
  --fx-paper:#0a0c11; --fx-panel:#0e121b; --fx-panel2:#141925;
  --fx-line:rgba(255,255,255,.09); --fx-line2:rgba(255,255,255,.18);
  --fx-ink:#fff; --fx-mut:rgba(255,255,255,.64); --fx-mut2:rgba(255,255,255,.42);
  --fx-acc:var(--accent,#6aa8ff); --fx-warm:#e5894b; --fx-ok:#4ade80;
  --fx-eo:cubic-bezier(.165,.84,.44,1);
  margin:0;
}

/* ---- the scene shell: depth-shadowed glass panel ---- */
.fx-sd{
  position:relative;
  background:linear-gradient(168deg,rgba(255,255,255,.04),rgba(255,255,255,.01)), var(--fx-panel);
  border:1px solid var(--fx-line2);
  border-radius:14px;
  box-shadow:0 30px 80px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.08);
  overflow:hidden;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

/* ---- header: brand/title + summary ---- */
.fx-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--fx-line)}
.fx-head__t{font-family:var(--font-display,"Clash Grotesk"),sans-serif;font-weight:500;font-size:15px;letter-spacing:-.01em;color:var(--fx-ink)}
.fx-head__ref{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--fx-mut2)}
.fx-head__sum{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:11px;color:var(--fx-mut);letter-spacing:.04em;white-space:nowrap}
.fx-head__sum b{color:var(--fx-ink)} .fx-head__sum .a{color:var(--fx-acc)}
.fx-head__live{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fx-acc)}
.fx-head__live .dot{width:6px;height:6px;border-radius:50%;background:var(--fx-ok);box-shadow:0 0 6px var(--fx-ok)}

.fx-body{padding:16px 20px}
.fx-lbl{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--fx-mut2);margin:0 0 12px}

/* ---- master/detail two-column body ---- */
.fx-split{display:grid;grid-template-columns:.92fr 1.08fr;min-height:300px}
.fx-split__l{padding:14px 14px;border-right:1px solid var(--fx-line);display:flex;flex-direction:column;gap:5px}
.fx-split__r{padding:18px 20px;display:flex;flex-direction:column;position:relative}

/* ---- selectable rows (master list / register) ---- */
.fx-row{display:grid;grid-template-columns:22px 1fr auto;gap:10px;align-items:center;padding:11px 12px;border-radius:9px;border:1px solid transparent;transition:background .3s var(--fx-eo),border-color .3s var(--fx-eo)}
.fx-row .rk{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:11px;color:var(--fx-mut2)}
.fx-row .nm{font-family:var(--font-display,"Clash Grotesk"),sans-serif;font-weight:500;font-size:14px;color:var(--fx-mut);line-height:1.2;overflow-wrap:anywhere}
.fx-row .sub{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--fx-mut2);margin-top:3px}
.fx-row .val{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:10px;color:var(--fx-mut2);white-space:nowrap}
.fx-row.on{background:rgba(106,168,255,.08);border-color:rgba(106,168,255,.3)}
.fx-row.on .rk,.fx-row.on .sub,.fx-row.on .val{color:var(--fx-acc)} .fx-row.on .nm{color:var(--fx-ink)}
.fx-row.warm.on{background:rgba(229,137,75,.08);border-color:rgba(229,137,75,.32)}
.fx-row.warm.on .rk,.fx-row.warm.on .sub,.fx-row.warm.on .val{color:var(--fx-warm)}

/* ---- detail panel: name + big value callout ---- */
.fx-detail__top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.fx-detail__name{font-family:var(--font-display,"Clash Grotesk"),sans-serif;font-weight:500;font-size:19px;letter-spacing:-.01em;margin:0;color:var(--fx-ink)}
.fx-detail__span{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:10px;color:var(--fx-mut);letter-spacing:.06em;text-transform:uppercase;margin-top:5px}
.fx-callout{font-family:var(--font-display,"Clash Grotesk"),sans-serif;font-weight:500;font-size:30px;letter-spacing:-.02em;color:var(--fx-acc);font-variant-numeric:tabular-nums;text-align:right;line-height:1}
.fx-callout__sub{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;color:var(--fx-mut2);letter-spacing:.08em;text-transform:uppercase;text-align:right;margin-top:4px}
.fx-detail__desc{font-family:var(--font-sans,"Figtree"),sans-serif;font-size:13.5px;line-height:1.55;color:var(--fx-mut);margin:16px 0 0}
.fx-detail__chips-k{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--fx-mut2);margin:20px 0 10px}
.fx-detail__chips{display:flex;flex-wrap:wrap;gap:7px}
.fx-detail__foot{margin-top:auto;display:flex;gap:22px;flex-wrap:wrap;padding-top:18px;font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:10px;color:var(--fx-mut);letter-spacing:.04em}
.fx-detail__foot b{color:var(--fx-ink)}

/* mini value/cost bars — fills a detail panel meaningfully (e.g. value vs build vs payback) */
.fx-bars{display:flex;flex-direction:column;gap:12px;margin-top:22px}
.fx-bar{display:grid;grid-template-columns:80px 1fr auto;gap:12px;align-items:center}
.fx-bar__k{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:var(--fx-mut2)}
.fx-bar__track{height:8px;border-radius:5px;background:rgba(255,255,255,.05);overflow:hidden}
.fx-bar__fill{height:100%;border-radius:5px;background:linear-gradient(90deg,rgba(106,168,255,.55),rgba(106,168,255,.2))}
.fx-bar__fill--warm{background:linear-gradient(90deg,rgba(229,137,75,.55),rgba(229,137,75,.2))}
.fx-bar__v{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:11px;color:var(--fx-ink);font-variant-numeric:tabular-nums;text-align:right;min-width:48px}

/* ---- mini gantt timeline ---- */
.fx-gantt{margin-top:22px}
.fx-gantt__head{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:end;margin-bottom:10px}
.fx-gantt__axis{position:relative;height:13px}
.fx-gantt__axis span{position:absolute;top:0;transform:translateX(-50%);font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;color:var(--fx-mut2);letter-spacing:.08em}
.fx-gantt__rows{display:flex;flex-direction:column;gap:8px}
.fx-prow{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:center}
.fx-prow .plbl{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9.5px;letter-spacing:.04em;color:var(--fx-ink);text-align:right;white-space:nowrap}
.fx-prow .ptrack{position:relative;height:22px;border-radius:5px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.045) 0 1px,transparent 1px 25%)}
.fx-prow .pbar{position:absolute;top:0;height:22px;border-radius:5px;background:linear-gradient(90deg,rgba(106,168,255,.32),rgba(106,168,255,.14));border:1px solid rgba(106,168,255,.45)}
.fx-prow.warm .pbar{background:linear-gradient(90deg,rgba(229,137,75,.30),rgba(229,137,75,.12));border-color:rgba(229,137,75,.45)}

/* ---- register table (status-led rows in a single column) ---- */
.fx-reg{display:flex;flex-direction:column}
.fx-reg__row{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:12px;align-items:center;padding:12px 6px;border-bottom:1px solid var(--fx-line);font-size:12px}
.fx-reg__row:last-child{border-bottom:none}
.fx-reg__row .id{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:11px;color:var(--fx-ink)}
.fx-reg__row .ds{font-size:12px;color:var(--fx-mut)}
.fx-reg__row .own{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:10px;color:var(--fx-mut2);text-transform:uppercase;letter-spacing:.06em}

/* ---- pills ---- */
.fx-pill{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:100px;border:1px solid transparent;white-space:nowrap}
.fx-pill--ok{color:var(--fx-acc);background:rgba(106,168,255,.12);border-color:rgba(106,168,255,.3)}
.fx-pill--warm{color:var(--fx-warm);background:rgba(229,137,75,.12);border-color:rgba(229,137,75,.32)}
.fx-pill--mut{color:var(--fx-mut);background:rgba(255,255,255,.05);border-color:var(--fx-line2)}
.fx-pill--ok2{color:var(--fx-ok);background:rgba(74,222,128,.12);border-color:rgba(74,222,128,.32)}

/* ---- metric strip ---- */
.fx-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.fx-metric{border:1px solid var(--fx-line);border-radius:8px;padding:14px;background:rgba(255,255,255,.012)}
.fx-metric .k{display:block;font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--fx-mut2)}
.fx-metric .v{display:block;font-family:var(--font-display,"Clash Grotesk"),sans-serif;font-weight:500;font-size:28px;letter-spacing:-.02em;margin-top:8px;font-variant-numeric:tabular-nums;color:var(--fx-ink)}
.fx-metric .v small{margin-left:1px}
.fx-metric .v small{font-size:13px;color:var(--fx-mut2)}
.fx-metric .v.acc{color:var(--fx-acc)}
.fx-spark{margin-top:14px}
.fx-spark svg{width:100%;height:30px;display:block}
.fx-spark .now{fill:none;stroke:var(--fx-acc);stroke-width:1.6}
.fx-spark .base{fill:none;stroke:var(--fx-line2);stroke-width:1.2;stroke-dasharray:3 3}
.fx-spark__lgnd{display:flex;gap:16px;margin-top:8px;font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--fx-mut2)}
.fx-spark__lgnd i{display:inline-block;width:14px;height:0;border-top:1.6px solid var(--fx-acc);vertical-align:middle;margin-right:5px}
.fx-spark__lgnd .b i{border-top:1.2px dashed var(--fx-line2)}

/* ---- status-strip footer (the "5/5 checks · 92% · instrumented" line) ---- */
.fx-foot{display:flex;gap:24px;flex-wrap:wrap;align-items:center;padding:13px 20px;border-top:1px solid var(--fx-line);background:rgba(255,255,255,.015)}
.fx-stat{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:10.5px;color:var(--fx-mut);letter-spacing:.03em}
.fx-stat b{color:var(--fx-ink)} .fx-stat .ck{color:var(--fx-acc)}
.fx-stat .dot{width:6px;height:6px;border-radius:50%;background:var(--fx-ok);box-shadow:0 0 6px var(--fx-ok)}
.fx-stat .dot--warm{background:var(--fx-warm);box-shadow:0 0 6px var(--fx-warm)}

@media (max-width:900px){
  .fx-split{grid-template-columns:1fr}
  .fx-split__l{border-right:none;border-bottom:1px solid var(--fx-line)}
  .fx-metrics{grid-template-columns:1fr}
  .fx-head{flex-wrap:wrap;gap:8px}
}

/* ---- layered stack: a thing on top, the layers that hold it up beneath ---- */
.fx-stack{display:flex;flex-direction:column;border:1px solid var(--fx-line);border-radius:9px;overflow:hidden}
.fx-stack__band{display:grid;grid-template-columns:108px minmax(0,1fr) auto;gap:18px;align-items:center;padding:15px 18px;border-top:1px solid var(--fx-line)}
.fx-stack__band:first-child{border-top:none}
.fx-stack__k{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--fx-mut2)}
.fx-stack__t{font-family:var(--font-display,"Clash Grotesk"),sans-serif;font-weight:500;font-size:15px;color:var(--fx-ink);letter-spacing:-.01em;line-height:1.15}
.fx-stack__d{font-size:12.5px;line-height:1.5;color:var(--fx-mut);margin-top:3px}
.fx-stack__tag{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--fx-mut2);white-space:nowrap}
.fx-stack__band--top{background:rgba(106,168,255,.10)}
.fx-stack__band--top .fx-stack__k,.fx-stack__band--top .fx-stack__tag{color:var(--fx-acc)}
.fx-stack__layer .fx-stack__k{color:var(--fx-acc)}
/* a thin "supported by" rule between the top thing and the foundation layers */
.fx-stack__seam{display:flex;align-items:center;gap:12px;padding:9px 18px;border-top:1px solid var(--fx-line);background:rgba(255,255,255,.015);font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--fx-mut2)}
.fx-stack__seam::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--fx-line),transparent)}

/* ---- linear pipeline: sequential steps + one branch ---- */
.fx-pipe__row{display:flex;align-items:stretch;gap:0}
.fx-pipe__step{flex:1;padding:13px 8px;border:1px solid var(--fx-line);border-radius:8px;background:rgba(255,255,255,.012);text-align:center}
.fx-pipe__arrow{flex:0 0 auto;display:flex;align-items:center;padding:0 7px;color:var(--fx-acc);font-size:15px}
.fx-pipe__n{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.1em;color:var(--fx-mut2)}
.fx-pipe__t{font-family:var(--font-display,"Clash Grotesk"),sans-serif;font-weight:500;font-size:14px;color:var(--fx-ink);margin-top:5px}
.fx-pipe__s{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:8.5px;letter-spacing:.03em;color:var(--fx-mut2);margin-top:4px}
.fx-pipe__step--decide{border-color:rgba(106,168,255,.45);background:rgba(106,168,255,.07)}
.fx-pipe__step--decide .fx-pipe__n{color:var(--fx-acc)}
.fx-pipe__branch{display:flex;flex-direction:column;align-items:center}
.fx-pipe__down{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--fx-warm);padding:10px 0 8px}
.fx-pipe__escalate{border:1px solid rgba(229,137,75,.4);background:rgba(229,137,75,.07);border-radius:8px;padding:12px 20px;text-align:center;min-width:300px}
.fx-pipe__escalate .fx-pipe__n{color:var(--fx-warm)}
.fx-pipe__writes{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--fx-line)}
.fx-pipe__writes-k{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--fx-mut2);margin-right:4px}
.fx-pipe__chip{font-family:var(--font-mono,"JetBrains Mono"),monospace;font-size:10px;letter-spacing:.04em;color:var(--fx-mut);border:1px solid var(--fx-line);border-radius:6px;padding:5px 11px}
@media (max-width:760px){
  .fx-pipe__row{flex-direction:column}
  .fx-pipe__arrow{transform:rotate(90deg);padding:7px 0;align-self:center}
  .fx-stack__band{grid-template-columns:72px minmax(0,1fr);gap:12px}
  .fx-stack__tag{display:none}
}

/* ---- interactivity affordances (figures.js drives the motion) ---- */
.fx-reg__row{transition:background .2s var(--fx-eo)}
.fx-reg__row:hover{background:rgba(255,255,255,.025)}
.fx-row{cursor:pointer;transition:background .25s var(--fx-eo),border-color .25s var(--fx-eo)}
.fx-row:hover{background:rgba(106,168,255,.05);border-color:rgba(106,168,255,.18)}
.fx-pipe__step{transition:border-color .25s var(--fx-eo),background .25s var(--fx-eo)}
.fx-pipe__step:hover{border-color:rgba(106,168,255,.4);background:rgba(106,168,255,.05)}
.fx-stack__band{transition:background .2s var(--fx-eo)}
.fx-stack__layer:hover{background:rgba(255,255,255,.03)}
/* live-feed row highlight (cycled by figures.js) */
.fx-reg__row{border-radius:6px}
.fx-reg__row.fx-live-on{background:rgba(106,168,255,.09)}
.fx-reg__row.fx-live-on .id{color:var(--fx-acc)}

/* ---- solution-page hero orb (the home contour-globe, on the hero right) ---- */
.rd-hero-orb{position:relative;width:100%;aspect-ratio:1/1}
.rd-hero-orb canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1;pointer-events:none}
.rd-hero-orb__glow{
  position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  width:104%;height:104%;border-radius:50%;z-index:0;pointer-events:none;
  background:
    radial-gradient(circle at 50% 62%, rgba(229,137,75,.26), rgba(229,137,75,.05) 36%, transparent 60%),
    radial-gradient(circle at 50% 26%, rgba(106,168,255,.15), transparent 46%);
  filter:blur(28px);
}
/* 2-column hero (copy + orb) when an orb is present */
main.page.rd .rd-section--hero .rd-hero-grid.rd-hero-grid--orb{
  grid-template-columns:minmax(0,1fr) minmax(300px,420px);
  gap:48px;align-items:center;
}
@media (max-width:860px){
  main.page.rd .rd-section--hero .rd-hero-grid.rd-hero-grid--orb{grid-template-columns:1fr}
  .rd-hero-orb{display:none}
}
