name: huashu-sparkline-arc description: | Narrative Sparkline (叙事波形) — Duarte-style narrative decks generated from the Sparkline叙事波形 spec (中性派, 还原91%) in 花叔 (alchaincyf)'s huashu-design references/design-styles.md. One oscillating SVG bézier waveform spans the full 1920×1080 canvas on every page; brand orange (#FF6B2C) marks only the turning points, greyed ghost lines carry the comparison, and stroke-dashoffset draws each segment progressively. Use when the user wants a change narrative, transformation story, before/after contrast, data story arc, speech-structure deck, 变革叙事, 数据故事, or a Duarte / sparkline-style presentation. triggers:
- "sparkline"
- "narrative arc deck"
- "data story deck"
- "duarte"
- "叙事波形"
- "变革叙事 PPT"
- "数据故事"
- "前后对照幻灯片" od: mode: deck surface: web preview: type: html entry: index.html design_system: requires: false example_prompt: "Use the Narrative Sparkline template to turn my change story into a Duarte-style HTML deck: 1920×1080 fixed canvas, one full-bleed SVG bézier waveform per page, brand-orange #FF6B2C turning-point annotations, greyed ghost comparison lines, stroke-dashoffset progressive reveal, Inter + Geist Mono. Start from example.html, replace the content only, and keep the design system intact." example_prompt_i18n: zh-CN: "用「叙事波形」模板把我的变革故事做成 Duarte 式 HTML 幻灯片:1920×1080 固定画布、每页一条横贯全屏的 SVG 贝塞尔波形线、品牌橙 #FF6B2C 只标转折点、灰化对照波形、stroke-dashoffset 逐段 reveal、Inter + Geist Mono 双字体。从 example.html 出发只换内容,不要重写设计。"
Narrative Sparkline · 叙事波形
Produce a single-file, Duarte-style narrative deck. You are a story
cartographer working in HTML: every page is built on one oscillating waveform
that travels between "what is" and "what could be", and orange appears only
where the story turns. The visual system, canvas contract, and navigation
runtime are locked by example.html. Start from example.html, replace
content only — do not rewrite the design or the script. Do not introduce any
color or font outside this spec.
Generated from the Sparkline叙事波形 / Narrative Sparkline (Duarte式) spec
(中性派, 还原91%) in references/design-styles.md of
huashu-design by 花叔
(alchaincyf), MIT licensed. Lineage: Nancy Duarte《Resonate》sparkline
structure, Al Gore An Inconvenient Truth, Duarte Inc. data storytelling.
Hard spec (locked — violating any line is a regression)
Canvas & runtime
- One
<div id="stage">fixed at 1920 × 1080 px, centered withposition: fixed; top: 50%; left: 50%; afit()function appliestranslate(-50%, -50%) scale(min(innerWidth/1920, innerHeight/1080))on load andresize. All inner layout in px — the scaler owns responsiveness. - Each page is one
<section class="slide">inside#stagewith adata-screen-label="01 封面"-style label; exactly one slide carries.active; dark pages add.dark. - Navigation (keep the script verbatim):
←/↑/PageUpprevious,→/↓/Space/PageDownnext,Home/Endfirst/last;#/Nhash routing (1-indexed) read on load +hashchange, written viahistory.replaceState; click left third = back, rest = forward; fixed counter pill bottom-right, key-hint bottom-left. No external JS, no build step — the file must open inside a sandboxed iframe viafile://.
Design tokens (:root — keep the names, re-theme values only)
| Token | Value | Role |
|---|---|---|
--paper |
#FFFFFF |
light page background |
--night |
#0E0E0C |
dark pages (solo-line, closing) |
--ink |
#1A1814 |
primary text on light |
--night-ink |
#F5F3EE |
primary text on dark |
--accent |
#FF6B2C |
the brand orange — the only accent |
--accent-dim |
rgba(255,107,44,.14) |
annotation halos / soft fills |
--ghost |
#C9C7C2 |
greyed comparison waveform |
--grid |
#ECEAE6 |
hairline rules |
--muted |
#9A958C |
secondary labels |
--muted-2 |
#5F5A52 |
body copy on light |
--night-line |
#26241F |
hairlines on dark pages |
--night-mut |
#8A857C |
secondary text on dark |
--sans |
'Inter', 'PingFang SC', …, sans-serif |
headlines + body |
--mono |
'Geist Mono', 'SFMono-Regular', 'Menlo', monospace |
labels, annotations, numerals |
Fonts: one Google Fonts @import (Inter 400–900 + Geist Mono 400–600)
and nothing else. No CDN scripts, no chart libraries, no images — every chart
is a hand-written inline SVG path. A second accent color is the cardinal sin
of this style; grey is the only other voice.
Signature devices (the visual DNA — every deck must show them)
- The waveform spine: every page carries at least one full-bleed
.sparkSVG with a smooth cubic-bézier oscillating path. Line layer usespreserveAspectRatio="none"so the path stretches; annotation dots/text live in a second, non-stretched SVG layer with the same viewBox so circles stay round and type stays true. Line weights:.arc5px orange hero line,.arc-thin3.5px,.ghost-line3px grey,.ghost-dashstroke-dasharray: 2 10grey baseline/industry reference. - Orange turning-point annotations:
.ptgroup = soft halo circle (--accent-dim), solid orange dot (r≈6–7), optional 2px orange ring for THE inflection point, plus Geist Mono uppercase.lab(12px, 2px tracking) and.val(20px, 600) value text. Grey.pt-ghostdots mark pain points on comparison lines. Orange marks turning points only — if every dot is orange, nothing turns. - Progressive reveal: paths carry
pathLength="1"+ classdraw(stroke-dasharray: 1; stroke-dashoffset: 1);.slide.active .drawanimatesstroke-dashoffsetto 0 (spark-draw, ~1.8s, ease-out-ish cubic-bezier). Segment stagger viad1/d2/d3, dot fade-ins viap1…p5(animation-delay ladder). Because.activetoggles display, the reveal replays every time a slide is entered — keep it that way. - Mono hairline chrome: 56px
.chrome-top/.chrome-bottomstrips on every page — Geist Mono 11px uppercase, 2px tracking,--gridhairline border (--night-lineon dark), org name left with an orange/separator, orange uppercase tag right, orangeP.NNpage marker bottom right. No solid bars, no logos — type and one hairline only. - Greyed contrast: every claim gets a comparison — dashed industry baseline, the old process line above the new one, or a flat ghost line under the rising arc. The grey line is the "what is"; the orange line is the "what could be".
- Mono numerals: giant numbers (
.giant, 160–220px Geist Mono 600, negative tracking,font-variant-numeric: tabular-nums) with one orange glyph (%, ×, unit); stat strips (.stat-strip) with a--gridtop hairline, 44px mono numbers and 11px uppercase captions.
Layout enumeration (use 6+ per deck, never one layout everywhere)
| Layout | Role |
|---|---|
cover |
giant statement headline (orange full stop) + waveform below with what-is / turn / new-bliss dots |
contents |
chapters hung directly on the waveform as numbered annotation points |
what-is |
left action-title column + low, flat grey waveform with dashed industry ghost + stat strip |
turning-point |
giant mono numeral + V-shaped inflection waveform, THE ringed orange dot, dated annotation |
before-after |
stacked contrast: grey jagged line top half, orange rising line bottom half, hairline divider |
solo-line |
dark page, one orange line crossing the void, one annotation, one big number |
evidence |
rising waveform with 4 labelled value dots + summary strip of mini inline-SVG sparklines |
roadmap |
three waveform segments revealed in sequence (d1/d2/d3) + three phase columns below |
quote |
orange SVG quote marks + 56px/800 quote with orange key phrase + ghost waveline footer |
closing |
dark page, 6px orange curve climbing out of the top-right edge + giant CTA |
Typography & narrative discipline
- Headlines: Inter 800–900, 54–108px, tracking −1.5 to −4px; the closing glyph (。 or .) of a hero headline is orange — never the whole headline.
- Body: 19px / 1.8
--muted-2, emphasized spans--ink700, max-width ~620px. Labels/annotations/numerals: always Geist Mono, uppercase, 2–4px tracking. Chinese copy uses 「」 quotes and full-width punctuation. - Default 10 pages (8–11 allowed). White pages dominate; at most 2–3 dark pages (solo-line + closing). Orange budget: turning points, annotation dots, chrome tags and single glyphs — roughly ≤ 5 orange touches per page.
- The deck must read as a Duarte sparkline: establish "what is" low, mark one explicit dated turning point, oscillate through evidence, end with the line climbing out of frame ("new bliss"). One story, one line.
- No emoji, no gradients, no shadows, no images, no chart libraries. Real
content only — the user's actual numbers and dates; missing data gets an
honest
<!-- 待用户提供 -->placeholder, never invented statistics. (The seed deck's 「澈流 / CHELIU」 data is fictional demo content and must be fully replaced.)
Workflow
- Clarify once: topic, audience, page count — and the story spine: what is the "what is", what is THE dated turning point, which 3–4 numbers prove the climb. This style dies without a real inflection moment.
- Copy
example.html, retitle, then replace each section's content following the layout enumeration. Keep chrome strips, spark/reveal CSS, token names, and the script intact. Reshape the bézier paths to match the user's actual data direction (down-then-up, stepped, etc.) but keep the two-layer SVG pattern andpathLength="1"reveal mechanics. - For ≥ 5 pages, showcase first: build the cover + the turning-point page, confirm the grammar, then batch the rest.
- Self-check before delivery: arrow through every page; counter and
#/Nhash stay in sync; reveal animation replays on each entry; no overflow beyond 1920×1080; annotation dots sit visually on their lines at 16:9; orange appears only at turning points; every page has the chrome strips and at least one waveform; no leftover demo (「澈流」/"CHELIU") text; grep forTODO.