/* ============================================================
   craftagent — signature diagrams (restyled + animated)
   Types: .cg (gates) · .cg2 (compare) · .cg-st (savepoint) · .cg-rip (ripple)
   Wrapper .diagram gets .in when scrolled into view → triggers animation
   ============================================================ */

.diagram{
  margin:40px 0 8px;padding:30px 26px 26px;background:var(--raise);
  border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);
  overflow:hidden;position:relative;
}
.diagram::before{
  content:"FIG";position:absolute;top:14px;right:18px;font-family:var(--mono);
  font-size:10px;letter-spacing:.2em;color:var(--ink-mute);opacity:.6;
}

/* ───────── GATES (.cg) — four gates on a task timeline ───────── */
.cg-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.24em;font-weight:600;color:var(--ink-mute);margin-bottom:30px;text-transform:uppercase}
.cg-row{display:flex;align-items:flex-start;gap:16px}
.cg-cap{flex:0 0 auto;font-family:var(--mono);font-size:11px;color:var(--ink-mute);margin-top:16px;white-space:nowrap;letter-spacing:.04em}
.cg-cap.end{color:var(--accent);font-weight:600}
.cg-line{position:relative;flex:1;display:flex;justify-content:space-between;padding:0 6px}
.cg-line::before{content:"";position:absolute;left:6px;right:6px;top:22px;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform 1s cubic-bezier(.6,.1,.2,1)}
.diagram.in .cg-line::before{transform:scaleX(1)}
.cg-gate{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;flex:1;min-width:0;opacity:0;transform:translateY(10px) scale(.85);transition:opacity .5s ease,transform .5s cubic-bezier(.2,1.4,.4,1)}
.diagram.in .cg-gate{opacity:1;transform:none}
.diagram.in .cg-gate:nth-child(1){transition-delay:.30s}
.diagram.in .cg-gate:nth-child(2){transition-delay:.52s}
.diagram.in .cg-gate:nth-child(3){transition-delay:.74s}
.diagram.in .cg-gate:nth-child(4){transition-delay:.96s}
.cg-badge{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--sans);font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px -4px var(--accent)}
.cg-lbl{text-align:center;margin-top:14px;padding:0 4px}
.cg-lbl b{display:block;font-family:var(--sans);font-size:14px;color:var(--ink);font-weight:700}
.cg-lbl span{display:block;font-family:var(--sans);font-size:11px;color:var(--ink-mute);margin-top:4px;line-height:1.35}

/* ───────── COMPARE (.cg2) — claim vs evidence / ask vs gate ───────── */
.cg2{display:flex;gap:18px;align-items:stretch}
.cg2 .col{flex:1;border-radius:14px;padding:18px 18px 15px;border:1px solid;opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s cubic-bezier(.2,.7,.2,1)}
.diagram.in .cg2 .col{opacity:1;transform:none}
.diagram.in .cg2 .col.bad{transition-delay:.1s}
.diagram.in .cg2 .col.good{transition-delay:.32s}
.cg2 .bad{background:var(--alert-bg);border-color:var(--alert-line)}
.cg2 .good{background:var(--good-bg);border-color:var(--good-line)}
.cg2 h4{margin:0 0 13px;font-family:var(--sans);font-size:14px;display:flex;align-items:center;gap:9px;color:var(--ink);font-weight:700}
.cg2 .m{width:23px;height:23px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex:0 0 auto}
.cg2 .m.x{background:var(--alert)}.cg2 .m.v{background:var(--good)}
.cg2 .step{background:var(--raise);border:1px solid var(--line);border-radius:9px;padding:10px 13px;font-family:var(--sans);font-size:13px;color:var(--ink-soft);line-height:1.45;margin-bottom:8px}
.cg2 .ar{text-align:center;color:var(--ink-mute);font-size:14px;margin:2px 0 8px;font-family:var(--mono)}

/* ───────── SAVEPOINT (.cg-st) — staged run with checkpoints ───────── */
.cg-st .cap{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-mute);padding:0 2px;margin-bottom:12px;letter-spacing:.06em;text-transform:uppercase}
.cg-st .lane{display:flex;align-items:center}
.cg-seg{flex:1;height:14px;background:var(--accent);border-radius:7px;transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.5,.1,.2,1)}
.diagram.in .cg-seg{transform:scaleX(1)}
.diagram.in .cg-seg:nth-of-type(1){transition-delay:.1s}
.diagram.in .cg-seg:nth-of-type(2){transition-delay:.55s}
.diagram.in .cg-seg:nth-of-type(3){transition-delay:1s}
.cg-flag{flex:0 0 auto;width:34px;display:flex;justify-content:center}
.cg-flag i{width:14px;height:14px;border-radius:50%;background:var(--good);box-shadow:0 0 0 5px var(--good-bg);transform:scale(0);transition:transform .4s cubic-bezier(.2,1.5,.4,1)}
.diagram.in .cg-flag:nth-of-type(2) i{transition-delay:.45s}
.diagram.in .cg-flag:nth-of-type(4) i{transition-delay:.9s}
.diagram.in .cg-flag i{transform:scale(1)}
.cg-note{font-family:var(--sans);text-align:center;font-size:13px;color:var(--ink-mute);margin-top:18px;line-height:1.5;max-width:52ch;margin-left:auto;margin-right:auto}

/* ───────── RIPPLE (.cg-rip) — blast radius from one change ───────── */
.cg-rip{position:relative;height:280px;display:flex;align-items:center;justify-content:center}
.cg-rip .ring{position:absolute;border-radius:50%;border:1.5px solid var(--accent);left:50%;top:50%;transform:translate(-50%,-50%) scale(.2);opacity:0}
.cg-rip .r1{width:120px;height:120px}.cg-rip .r2{width:200px;height:200px}.cg-rip .r3{width:280px;height:280px}
.diagram.in .cg-rip .ring{animation:ripple 2.6s cubic-bezier(.2,.7,.2,1) infinite}
.diagram.in .cg-rip .r1{animation-delay:0s}
.diagram.in .cg-rip .r2{animation-delay:.5s}
.diagram.in .cg-rip .r3{animation-delay:1s}
@keyframes ripple{0%{transform:translate(-50%,-50%) scale(.3);opacity:0}25%{opacity:.6}100%{transform:translate(-50%,-50%) scale(1);opacity:0}}
.cg-rip .core{position:relative;z-index:2;background:var(--accent);color:#fff;border-radius:50%;width:96px;height:96px;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--sans);font-size:12px;font-weight:700;line-height:1.25;box-shadow:0 8px 22px -6px var(--accent);padding:10px}
.cg-rip .hit{position:absolute;background:var(--raise);border:1px solid var(--line);border-radius:9px;padding:6px 12px;font-family:var(--sans);font-size:12px;color:var(--ink-soft);box-shadow:var(--shadow-sm);white-space:nowrap;z-index:3;opacity:0;transform:scale(.8);transition:opacity .5s ease,transform .5s cubic-bezier(.2,1.4,.4,1)}
.diagram.in .cg-rip .hit{opacity:1;transform:none}
.diagram.in .cg-rip .ht{transition-delay:1.3s}
.diagram.in .cg-rip .hr{transition-delay:1.45s}
.diagram.in .cg-rip .hb{transition-delay:1.6s}
.diagram.in .cg-rip .hl{transition-delay:1.75s}
.cg-rip .ht{top:10px;left:50%;transform:translateX(-50%)}.diagram.in .cg-rip .ht{transform:translateX(-50%)}
.cg-rip .hr{right:6px;top:50%;transform:translateY(-50%)}.diagram.in .cg-rip .hr{transform:translateY(-50%)}
.cg-rip .hb{bottom:10px;left:50%;transform:translateX(-50%)}.diagram.in .cg-rip .hb{transform:translateX(-50%)}
.cg-rip .hl{left:6px;top:50%;transform:translateY(-50%)}.diagram.in .cg-rip .hl{transform:translateY(-50%)}

/* ───────── hero mini-gates (landing) ───────── */
.mini-gates{display:flex;align-items:stretch;gap:0;width:100%}
.mini-gate{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;padding:0 2px}
.mini-gate .track{position:absolute;top:21px;left:0;right:0;height:2px;background:var(--line-2);transition:background .6s ease}
.mini-gate:first-child .track{left:50%}.mini-gate:last-child .track{right:50%}
.mini-gate.fill .track{background:var(--accent)}
.mini-gate .mb{position:relative;z-index:1;width:44px;height:44px;border-radius:50%;border:2px solid var(--accent);background:var(--raise);color:var(--accent);display:grid;place-items:center;font-family:var(--sans);font-weight:800;font-size:16px}
.mini-gate.fill .mb{background:var(--accent);color:#fff}
.mini-gate .ml{font-family:var(--sans);font-size:11px;color:var(--ink-soft);margin-top:11px;text-align:center;line-height:1.25;font-weight:600}

/* gate-label icon (added to .cg gates) */
.cg-lbl .cg-ico{display:block;width:19px;height:19px;margin:0 auto 7px;color:var(--accent);opacity:0;transform:translateY(4px);transition:opacity .5s ease,transform .5s ease}
.cg-lbl .cg-ico svg{width:100%;height:100%}
.diagram.in .cg-gate:nth-child(1) .cg-ico{transition-delay:.42s;opacity:1;transform:none}
.diagram.in .cg-gate:nth-child(2) .cg-ico{transition-delay:.64s;opacity:1;transform:none}
.diagram.in .cg-gate:nth-child(3) .cg-ico{transition-delay:.86s;opacity:1;transform:none}
.diagram.in .cg-gate:nth-child(4) .cg-ico{transition-delay:1.08s;opacity:1;transform:none}

/* ───────── PERSONA (.cg-persona) — who the agent really is ───────── */
.cg-persona .cgp-traits{display:flex;gap:14px}
.cg-persona .cgp-t{flex:1;min-width:0;background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:20px 14px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s cubic-bezier(.2,.7,.2,1)}
.diagram.in .cg-persona .cgp-t{opacity:1;transform:none}
.diagram.in .cg-persona .cgp-t:nth-child(1){transition-delay:.08s}
.diagram.in .cg-persona .cgp-t:nth-child(2){transition-delay:.24s}
.diagram.in .cg-persona .cgp-t:nth-child(3){transition-delay:.40s}
.cg-persona .cgp-i{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;margin-bottom:13px}
.cg-persona .cgp-i svg{width:23px;height:23px}
.cg-persona .cgp-i.ok{background:var(--wash);color:var(--accent);box-shadow:0 0 0 1px var(--accent-ink) inset}
.cg-persona .cgp-i.warn{background:var(--alert-bg);color:var(--alert);box-shadow:0 0 0 1px var(--alert-line) inset}
.cg-persona .cgp-t b{font-family:var(--sans);font-size:15px;font-weight:700;color:var(--ink)}
.cg-persona .cgp-t span{font-family:var(--sans);font-size:12.5px;color:var(--ink-mute);margin-top:5px;line-height:1.4}
.cg-persona .cgp-line{margin-top:20px;text-align:center;font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink-soft);line-height:1.5}
.cg-persona .cgp-line b{font-style:normal;color:var(--accent);font-weight:500}

/* ───────── PROMPT DECK (.cg-deck) — exact words at each gate ───────── */
.cg-deck{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cg-deck .cgd-c{display:flex;gap:14px;background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:16px 18px;opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s cubic-bezier(.2,.7,.2,1)}
.diagram.in .cg-deck .cgd-c{opacity:1;transform:none}
.diagram.in .cg-deck .cgd-c:nth-child(1){transition-delay:.06s}
.diagram.in .cg-deck .cgd-c:nth-child(2){transition-delay:.20s}
.diagram.in .cg-deck .cgd-c:nth-child(3){transition-delay:.34s}
.diagram.in .cg-deck .cgd-c:nth-child(4){transition-delay:.48s}
.cg-deck .cgd-n{flex:0 0 auto;font-family:var(--serif);font-style:italic;font-size:30px;line-height:1;color:color-mix(in srgb,var(--accent) 42%,transparent);width:28px;text-align:center}
.cg-deck .cgd-b{min-width:0}
.cg-deck .cgd-b b{display:flex;align-items:center;gap:8px;font-family:var(--sans);font-size:14px;font-weight:700;color:var(--ink);margin-bottom:9px}
.cg-deck .cgd-i{display:inline-flex;width:17px;height:17px;color:var(--accent);flex:0 0 auto}
.cg-deck .cgd-i svg{width:100%;height:100%}
.cg-deck .cgd-b p{margin:0;font-family:var(--mono);font-size:12.5px;line-height:1.55;color:var(--ink-soft);background:var(--raise);border-left:2px solid var(--accent);border-radius:0 8px 8px 0;padding:9px 12px}

/* ───────── COST ASYMMETRY (.cg-cost) — cheap now vs expensive later ───────── */
.cg-cost{display:flex;flex-direction:column;gap:14px;padding:4px 0}
.cg-cost .cgc-row{display:grid;grid-template-columns:190px 1fr auto;align-items:center;gap:16px}
.cg-cost .cgc-lb{display:flex;align-items:center;gap:9px;font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--ink)}
.cg-cost .cgc-i{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto}
.cg-cost .cgc-i svg{width:17px;height:17px}
.cg-cost .cgc-i.ok{background:var(--good-bg);color:var(--good)}
.cg-cost .cgc-i.warn{background:var(--alert-bg);color:var(--alert)}
.cg-cost .cgc-track{height:14px;background:var(--paper-2);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.cg-cost .cgc-fill{display:block;height:100%;width:0;border-radius:7px;transition:width 1.1s cubic-bezier(.5,.1,.2,1)}
.diagram.in .cg-cost .cgc-fill{width:var(--w)}
.cg-cost .cgc-fill.cheap{background:linear-gradient(90deg,var(--good),color-mix(in srgb,var(--good) 70%,var(--accent)))}
.cg-cost .cgc-fill.dear{background:linear-gradient(90deg,var(--accent),var(--alert))}
.diagram.in .cg-cost .cgc-fill.dear{transition-delay:.35s}
.cg-cost .cgc-v{font-family:var(--mono);font-size:12px;color:var(--ink-mute);white-space:nowrap}

/* ───────── TELLS (.cg-tells) — tell-tale signals to watch for ───────── */
.cg-tells{padding:2px 0}
.cg-tells .ct-h{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:16px}
.cg-tells .ct-list{display:flex;flex-direction:column;gap:11px}
.cg-tells .ct-item{display:flex;gap:13px;align-items:flex-start;background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:13px 15px;opacity:0;transform:translateX(-10px);transition:opacity .5s ease,transform .5s cubic-bezier(.2,.7,.2,1)}
.diagram.in .cg-tells .ct-item{opacity:1;transform:none}
.diagram.in .cg-tells .ct-item:nth-child(1){transition-delay:.08s}
.diagram.in .cg-tells .ct-item:nth-child(2){transition-delay:.20s}
.diagram.in .cg-tells .ct-item:nth-child(3){transition-delay:.32s}
.diagram.in .cg-tells .ct-item:nth-child(4){transition-delay:.44s}
.cg-tells .ct-i{flex:0 0 auto;width:26px;height:26px;border-radius:7px;background:var(--alert-bg);color:var(--alert);display:grid;place-items:center;margin-top:1px}
.cg-tells .ct-i svg{width:15px;height:15px}
.cg-tells .ct-tx{min-width:0}
.cg-tells .ct-tx b{display:block;font-family:var(--sans);font-size:13.5px;font-weight:700;color:var(--ink);margin-bottom:3px}
.cg-tells .ct-tx span{display:block;font-family:var(--sans);font-size:12.5px;color:var(--ink-mute);line-height:1.45}

@media(max-width:640px){
  .cg-row{flex-direction:column;gap:0}
  .cg-cap{display:none}
  .cg-line{flex-direction:column;gap:22px;padding:0}
  .cg-line::before{display:none}
  .cg-gate{flex-direction:row;gap:15px;align-items:center;width:100%}
  .cg-lbl{text-align:left;margin-top:0}
  .cg-lbl .cg-ico{margin:0 0 5px}
  .cg2{flex-direction:column}
  .cg-rip .hit{font-size:11px;padding:4px 9px}
  .cg-persona .cgp-traits{flex-direction:column;gap:10px}
  .cg-persona .cgp-t{flex-direction:row;text-align:left;gap:13px;align-items:center;padding:13px 15px}
  .cg-persona .cgp-i{margin-bottom:0}
  .cg-deck{grid-template-columns:1fr}
  .cg-cost .cgc-row{grid-template-columns:1fr;gap:7px}
  .cg-cost .cgc-track{order:3}
}

/* ============================================================
   MAP-PAGE CLUSTER DIAGRAMS — .cviz + .cv1..cv10 (GARDEN-042)
   10 context "talking" diagrams · refined frame + scroll-drawn motion
   ============================================================ */
.cviz{position:relative;margin:26px 0 6px;padding:22px 24px 22px;border-radius:18px;
  background:linear-gradient(165deg,color-mix(in srgb,var(--raise) 82%,transparent),color-mix(in srgb,var(--paper-2) 60%,transparent));
  border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden}
.cviz::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(110% 70% at 100% 0,var(--wash),transparent 58%);opacity:.55}
.cviz::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--accent),var(--accent-ink));opacity:0;transform:scaleY(0);transform-origin:top;transition:opacity .4s,transform .5s var(--ease)}
.cviz.in::after{opacity:1;transform:scaleY(1)}
.cviz .vlab{position:relative;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:18px;display:flex;justify-content:space-between;align-items:center}
.cviz .vlab b{color:var(--accent);font-weight:600;letter-spacing:.14em}
.cviz svg{display:block;overflow:visible;position:relative}
.cviz .draw{stroke-dasharray:var(--len);stroke-dashoffset:var(--len)}
.cviz.in .draw{animation:cvDraw 1s var(--ease) forwards}
.cviz.in .draw.d2{animation-delay:.25s}.cviz.in .draw.d3{animation-delay:.5s}.cviz.in .draw.d4{animation-delay:.75s}
@keyframes cvDraw{to{stroke-dashoffset:0}}
.cviz .pop{transform:scale(.72);transform-box:fill-box;transform-origin:center}
.cviz.in .pop{animation:cvPop .5s var(--spring) forwards}
@keyframes cvPop{from{transform:scale(.72)}to{transform:scale(1)}}
.cviz .fade{opacity:0;transition:opacity .6s var(--ease)}
.cviz.in .fade{opacity:1}
@keyframes cvFlow{to{stroke-dashoffset:-100}}
@keyframes cvPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.18);opacity:.7}}
@keyframes cvFlicker{0%,100%{opacity:.25}8%{opacity:1}16%{opacity:.4}24%{opacity:.9}40%{opacity:.3}}
@keyframes cvShimmer{from{transform:translateX(-120%)}to{transform:translateX(320%)}}

/* 1 — control */
.cv1 .row{display:flex;align-items:center;gap:14px;padding:6px 0}
.cv1 .src{flex:0 0 auto;font-family:var(--mono);font-size:11px;font-weight:600;padding:7px 11px;border-radius:8px;border:1px solid var(--line);background:var(--raise);color:var(--ink)}
.cv1 .src.bad{border-style:dashed;color:var(--ink-mute)}
.cv1 .src.good{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 3px var(--wash)}
.cv1 svg{flex:1;height:56px;width:100%}
.cv1 .div{stroke:var(--ink-mute);stroke-width:1.5;stroke-dasharray:4 5;fill:none;opacity:.55}
.cv1.in .div{animation:cvFlow 1.6s linear infinite}
.cv1 .conv{stroke:var(--accent);stroke-width:2.5;fill:none}
.cv1 .qd{fill:var(--ink-mute);opacity:.5}
.cv1.in .qd{animation:cvPulse 1.8s ease-in-out infinite}
.cv1 .end{font-family:var(--mono);font-size:11px;color:var(--ink-mute);white-space:nowrap}
.cv1 .end.ok{color:var(--good);font-weight:600}
.cv1 .spark{fill:var(--accent)}

/* 2 — context budget bar */
.cv2 .bar{position:relative;display:flex;height:36px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--raise)}
.cv2 .seg{height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;color:#fff;transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease);white-space:nowrap}
.cv2.in .seg{transform:scaleX(1)}
.cv2 .seg.keep{background:linear-gradient(120deg,var(--accent),var(--accent-ink))}
.cv2 .seg.keep2{background:color-mix(in srgb,var(--accent) 64%,var(--ink))}
.cv2 .seg.drop{background:repeating-linear-gradient(45deg,var(--line) 0 6px,var(--paper-2) 6px 12px);color:var(--ink-mute)}
.cv2.in .seg:nth-child(2){transition-delay:.15s}.cv2.in .seg:nth-child(3){transition-delay:.3s}
.cv2 .shine{position:absolute;top:0;bottom:0;width:46%;pointer-events:none;
  background:linear-gradient(100deg,transparent,color-mix(in srgb,#fff 88%,transparent) 50%,transparent)}
.cv2.in .shine{animation:cvShimmer 2.3s ease-in-out .4s infinite}
.cv2.in .bar{animation:barGlow 2.8s ease-in-out infinite}
@keyframes barGlow{0%,100%{box-shadow:0 0 0 0 transparent}50%{box-shadow:0 0 0 3px var(--wash)}}
.cv2 .legend{display:flex;gap:18px;margin-top:12px}
.cv2 .legend span{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute);display:inline-flex;align-items:center;gap:6px}
.cv2 .legend i{width:10px;height:10px;border-radius:3px}

/* 3 — orchestration */
.cv3 svg{width:100%;height:104px}
.cv3 .flow{stroke:var(--line-2);stroke-width:2.5;fill:none}
.cv3 .flow.lit{stroke:var(--accent);stroke-width:3}
.cv3 .ag{fill:var(--raise);stroke:var(--accent);stroke-width:2}
.cv3 .agt{font-family:var(--mono);font-size:11px;fill:var(--accent);font-weight:600;text-anchor:middle;dominant-baseline:central}
.cv3 .merge{fill:var(--accent)}
.cv3 .mt{font-family:var(--mono);font-size:10px;fill:#fff;text-anchor:middle;dominant-baseline:central}
.cv3 .spark{fill:var(--accent)}

/* 5 — production */
.cv5 svg{width:100%;height:88px}
.cv5 .safe{stroke:var(--good);stroke-width:3;fill:none}
.cv5.in .safe{filter:drop-shadow(0 0 5px color-mix(in srgb,var(--good) 50%,transparent))}
.cv5 .edge{stroke:var(--alert);stroke-width:3;fill:none;stroke-dasharray:5 5}
.cv5.in .edge{animation:cvFlow 1.2s linear infinite}
.cv5 .zone{font-family:var(--mono);font-size:10px;fill:var(--ink-mute);text-anchor:middle}
.cv5 .x{stroke:var(--alert);stroke-width:2.5}
.cv5.in .xg{animation:cvFlicker 2.4s ease-in-out infinite}
.cv5 .trav5{fill:var(--good);filter:drop-shadow(0 0 4px color-mix(in srgb,var(--good) 70%,transparent))}

/* 6 — economics bars */
.cv6{display:flex;flex-direction:column;gap:12px}
.cv6 .r{display:grid;grid-template-columns:120px 1fr auto;align-items:center;gap:14px}
.cv6 .k{font-family:var(--sans);font-size:12.5px;color:var(--ink);font-weight:600}
.cv6 .track{position:relative;height:22px;border-radius:8px;background:var(--paper-2);border:1px solid var(--line);overflow:hidden}
.cv6 .fill{position:relative;height:100%;width:0;border-radius:7px;transition:width 1s var(--ease)}
.cv6.in .fill{width:var(--w)}
.cv6 .fill.a{background:linear-gradient(90deg,var(--good),color-mix(in srgb,var(--good) 55%,var(--accent)))}
.cv6 .fill.b{background:linear-gradient(90deg,var(--accent),var(--accent-ink))}
.cv6 .fill.c{background:linear-gradient(90deg,var(--accent),var(--alert))}
.cv6.in .fill.b{transition-delay:.2s}.cv6.in .fill.c{transition-delay:.4s}
.cv6 .fill .sh{position:absolute;inset:0;background:linear-gradient(100deg,transparent,color-mix(in srgb,#fff 68%,transparent),transparent);transform:translateX(-120%)}
.cv6.in .fill .sh{animation:cvShimmer 2.6s ease-in-out .5s infinite}
.cv6.in .fill.b .sh{animation-delay:.7s}.cv6.in .fill.c .sh{animation-delay:1.1s}
.cv6.in .fill.c{animation:cardAlert 2.2s ease-in-out 1.4s infinite}
@keyframes cardAlert{0%,100%{box-shadow:0 0 0 0 transparent}50%{box-shadow:0 0 14px -2px color-mix(in srgb,var(--alert) 70%,transparent)}}
.cv6 .v{font-family:var(--mono);font-size:11px;color:var(--ink-mute);white-space:nowrap}

/* 7 — stages */
.cv7 svg{width:100%;height:118px}
.cv7 .path{stroke:url(#cv7grad);stroke-width:2.5;fill:none}
.cv7 .pt{fill:var(--raise);stroke:var(--accent);stroke-width:2}
.cv7 .pt.danger{fill:var(--alert);stroke:var(--alert)}
.cv7.in .pt.danger{animation:cvPulse 1.6s ease-in-out infinite}
.cv7 .lbl{font-family:var(--mono);font-size:10px;fill:var(--ink-mute);text-anchor:middle}
.cv7 .lbl.danger{fill:var(--alert);font-weight:600}
.cv7 .gd{font-family:var(--mono);font-size:10px;fill:var(--ink-mute);text-anchor:middle}
.cv7 .flag{font-family:var(--sans);font-size:11px;fill:var(--alert);font-weight:700;text-anchor:middle}

/* 8 — tooling */
.cv8{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cviz.cv8 .vlab,.cviz.cv10 .vlab{grid-column:1/-1}
.cv8 .doc{position:relative;border:1px solid var(--line);border-radius:12px;padding:14px;background:var(--raise);transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;overflow:hidden}
.cv8 .doc.passive{opacity:.66}
.cv8 .doc.active{border-color:var(--accent);border-left-width:3px}
.cv8.in .doc.active{transform:translateY(-3px);box-shadow:0 10px 26px -12px var(--accent)}
.cv8 .doc .h{font-family:var(--sans);font-size:12.5px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:7px;margin-bottom:9px}
.cv8 .doc .h .i{width:16px;height:16px;color:var(--ink-mute);display:inline-flex}
.cv8 .doc .h .i svg{width:16px;height:16px}
.cv8 .doc.active .h .i{color:var(--accent)}
.cv8.in .doc.active .h .i{animation:cvPulse 2.4s ease-in-out 1s infinite}
.cv8 .doc .ln{height:6px;border-radius:3px;background:var(--line);margin:6px 0;transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.cv8.in .doc .ln{transform:scaleX(1)}
.cv8.in .doc .ln:nth-of-type(2){transition-delay:.12s}.cv8.in .doc .ln:nth-of-type(3){transition-delay:.24s}
.cv8 .doc.active .ln{background:color-mix(in srgb,var(--accent) 38%,transparent)}
.cv8 .doc .ln.s{width:70%}.cv8 .doc .ln.m{width:92%}
.cv8 .doc .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);margin-top:11px;display:block}
.cv8 .doc.active .tag{color:var(--accent)}
.cv8 .scan{position:absolute;top:0;bottom:0;left:0;width:42%;pointer-events:none;
  background:linear-gradient(100deg,transparent,color-mix(in srgb,var(--accent) 22%,transparent),transparent);transform:translateX(-130%)}
.cv8.in .doc.active .scan{animation:cvShimmer 3.2s ease-in-out 1.2s infinite}
.cv8 .badge{position:absolute;top:11px;right:11px;font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.03em;color:#fff;background:var(--accent);padding:3px 7px;border-radius:6px;transform:scale(.5);transform-origin:center}
.cv8.in .badge{animation:cvPop .55s var(--spring) .9s backwards}

/* 9 — autonomy dial */
.cv9 .scale{position:relative;height:8px;border-radius:6px;margin:34px 10px 8px;
  background:linear-gradient(90deg,var(--good),var(--accent) 55%,var(--alert));box-shadow:0 1px 6px -2px var(--accent)}
.cv9 .scale .tick{position:absolute;top:-6px;width:1px;height:20px;background:var(--line-2);transform:translateX(-50%)}
.cv9 .scale .handle{position:absolute;top:50%;left:52%;width:22px;height:22px;border-radius:50%;background:var(--raise);border:3px solid var(--accent);transform:translate(-50%,-50%) scale(0);box-shadow:0 4px 14px -3px var(--accent);transition:transform .5s var(--spring) .3s}
.cv9.in .scale .handle{transform:translate(-50%,-50%) scale(1);animation:dialBreathe 3.4s ease-in-out 1s infinite}
@keyframes dialBreathe{0%,100%{left:48%}50%{left:58%}}
.cv9 .scale .ph{position:absolute;top:-30px;left:52%;transform:translateX(-50%);font-family:var(--mono);font-size:9.5px;color:var(--accent);white-space:nowrap;opacity:0;transition:opacity .4s .6s}
.cv9.in .scale .ph{opacity:1}
.cv9 .ends{display:flex;justify-content:space-between;margin:0 4px}
.cv9 .ends span{font-family:var(--mono);font-size:10.5px;color:var(--ink-mute)}
.cv9 .dims{display:flex;gap:8px;margin-top:18px}
.cv9 .dim{flex:1;font-family:var(--sans);font-size:11px;color:var(--ink-soft);text-align:center;padding:10px 6px;border:1px solid var(--line);border-radius:10px;background:var(--raise);opacity:0;transform:translateY(8px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.cv9.in .dim{opacity:1;transform:none}
.cv9.in .dim:nth-child(2){transition-delay:.12s}.cv9.in .dim:nth-child(3){transition-delay:.24s}
.cv9 .dim b{display:block;color:var(--accent);font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}

/* 10 — measure sparklines */
.cv10{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cv10 .m{position:relative;border:1px solid var(--line);border-radius:12px;padding:13px 14px;background:var(--raise);overflow:hidden}
.cv10 .m .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute)}
.cv10 .m .val{font-family:var(--serif);font-style:italic;font-weight:500;font-size:24px;color:var(--accent);line-height:1;margin:6px 0 8px;display:flex;align-items:baseline;gap:6px}
.cv10 .m .val small{font-family:var(--mono);font-size:11px;font-style:normal;color:var(--ink-mute)}
.cv10 .m svg{width:100%;height:32px}
.cv10 .m .spark{stroke:var(--accent);stroke-width:2;fill:none}
.cv10 .m .sparkfill{stroke:none;opacity:0;transition:opacity .8s .5s}
.cv10.in .m .sparkfill{opacity:1}
.cv10 .m .grid{stroke:var(--line);stroke-width:1;opacity:.55;vector-effect:non-scaling-stroke}

@media(max-width:980px){.cv8{grid-template-columns:1fr}.cv10{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){
  .cv6 .r{grid-template-columns:1fr;gap:5px}
  .cv9 .dims{flex-direction:column}
  .cv10{grid-template-columns:1fr}
}
