:root{color-scheme:dark light;--bg: #0b1020;--bg-soft: #131a30;--bg-elev: #1a2240;--line: #283055;--line-strong: #3b4583;--text: #e7ecff;--text-dim: #9aa4cf;--text-mute: #6f7aa8;--accent: #7dd3fc;--accent-2: #a78bfa;--accent-3: #f472b6;--warn: #fbbf24;--good: #34d399;--bad: #f87171;--code-bg: #0e1530;--code-inline-bg: #16204a;--shadow: 0 10px 40px rgba(0, 0, 0, 0.45);--radius: 12px;--mono: ui-monospace, "JetBrains Mono", "Fira Code", Menlo, Consolas, monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, sans-serif}@media (prefers-color-scheme: light){:root{--bg: #f6f7fc;--bg-soft: #ffffff;--bg-elev: #ffffff;--line: #e1e4f1;--line-strong: #b8bfe2;--text: #0b1020;--text-dim: #4a5285;--text-mute: #7a83b0;--code-bg: #f1f3ff;--code-inline-bg: #eef1ff;--shadow: 0 8px 28px rgba(20, 28, 80, 0.08)}}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--accent);text-decoration:none;transition:color .12s ease}a:hover{text-decoration:underline}code{font-family:var(--mono);font-size:.92em;padding:1px 6px;border-radius:4px;background:var(--code-inline-bg);color:var(--text)}pre{font-family:var(--mono);background:var(--code-bg);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;overflow-x:auto;font-size:13.5px;line-height:1.55}pre>code{background:rgba(0,0,0,0);padding:0;border-radius:0}hr{border:0;border-top:1px solid var(--line);margin:32px 0}table{width:100%;border-collapse:collapse;margin:12px 0 18px;font-size:14px}th,td{text-align:left;padding:8px 12px;border-bottom:1px solid var(--line)}th{font-weight:600;color:var(--text);background:var(--bg-soft)}blockquote{margin:16px 0;padding:10px 16px;border-left:3px solid var(--accent);background:var(--bg-soft);border-radius:4px;color:var(--text-dim)}.container{width:100%;max-width:1180px;margin:0 auto;padding:0 24px}.container.narrow{max-width:820px}.site-nav{position:sticky;top:0;z-index:30;background:color-mix(in srgb, var(--bg) 88%, rgba(0,0,0,0));backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line)}.site-nav .inner{display:flex;align-items:center;gap:24px;height:60px}.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.5px;font-size:18px;color:var(--text)}.brand:hover{text-decoration:none}.brand .dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg, var(--accent), var(--accent-2));box-shadow:0 0 18px var(--accent)}.nav-links{display:flex;gap:18px;margin-left:auto;align-items:center;flex-wrap:wrap}.nav-links a{color:var(--text-dim);font-weight:500}.nav-links a:hover,.nav-links a.active{color:var(--text);text-decoration:none}.nav-links .gh{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--line);border-radius:999px;font-size:13px}.nav-links .gh:hover{border-color:var(--accent);color:var(--text)}.hero{position:relative;padding:88px 0 56px;overflow:hidden}.hero::before{content:"";position:absolute;inset:-20% -10% auto -10%;height:70%;background:radial-gradient(60% 60% at 20% 30%, color-mix(in srgb, var(--accent) 22%, rgba(0,0,0,0)), rgba(0,0,0,0) 70%),radial-gradient(50% 50% at 80% 20%, color-mix(in srgb, var(--accent-2) 25%, rgba(0,0,0,0)), rgba(0,0,0,0) 70%),radial-gradient(40% 40% at 50% 80%, color-mix(in srgb, var(--accent-3) 18%, rgba(0,0,0,0)), rgba(0,0,0,0) 70%);filter:blur(40px);pointer-events:none;z-index:0}.hero .inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center}.hero h1{font-size:clamp(36px,5vw,56px);line-height:1.05;margin:0 0 18px;letter-spacing:-.02em}.hero h1 .grad{background:linear-gradient(110deg, var(--accent), var(--accent-2) 50%, var(--accent-3));-webkit-background-clip:text;background-clip:text;color:rgba(0,0,0,0)}.hero p.lede{font-size:18px;color:var(--text-dim);max-width:56ch;margin:0 0 28px}.hero .cta-row{display:flex;flex-wrap:wrap;gap:12px}.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-strong);background:var(--bg-elev);color:var(--text);padding:11px 18px;border-radius:10px;font-weight:600;font-size:15px;cursor:pointer;transition:transform .06s ease,border-color .15s ease,background .15s ease,filter .15s ease;font-family:var(--sans)}.btn:hover{text-decoration:none;border-color:var(--accent)}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#0b1020;border-color:rgba(0,0,0,0)}.btn-primary:hover{filter:brightness(1.06)}.btn-ghost{background:rgba(0,0,0,0)}.hero-preview{position:relative;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-soft);box-shadow:var(--shadow);overflow:hidden}.hero-preview header{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--bg-elev);font-size:12px;color:var(--text-mute)}.hero-preview header .dots{display:flex;gap:6px;margin-right:10px}.hero-preview header .dots span{width:10px;height:10px;border-radius:50%;background:var(--line-strong)}.hero-preview .split{display:grid;grid-template-columns:1fr 1fr;min-height:320px}.hero-preview pre{margin:0;padding:18px;border-right:1px solid var(--line);background:var(--code-bg);overflow:auto;font-size:13px;line-height:1.55;color:var(--text);border-radius:0}.hero-preview .render{display:flex;align-items:center;justify-content:center;padding:18px;background:#fff}.hero-preview .render svg{max-width:100%;height:auto}.stats{display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:12px;padding:14px 0 0}.stat{border:1px solid var(--line);border-radius:10px;padding:14px 16px;background:var(--bg-soft)}.stat .v{font-size:24px;font-weight:700;letter-spacing:-.02em}.stat .k{font-size:12px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.08em}.section{padding:64px 0;border-top:1px solid var(--line)}.section h2{font-size:28px;letter-spacing:-.01em;margin:0 0 8px}.section .sub{color:var(--text-dim);margin:0 0 28px;max-width:70ch}.feature-grid{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:16px}.feature{border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:var(--bg-soft)}.feature h3{margin:8px 0 6px;font-size:16px}.feature p{margin:0;font-size:14px;color:var(--text-dim)}.feature .icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg, var(--accent), var(--accent-2));display:inline-grid;place-items:center;color:#0b1020;font-weight:800;font-size:18px}.matrix{display:grid;grid-template-columns:repeat(3, 1fr);gap:12px}.matrix .lang{border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-soft);padding:18px}.matrix .lang h3{margin:0 0 6px;display:flex;align-items:center;gap:8px;font-size:16px}.tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;background:color-mix(in srgb, var(--accent) 18%, rgba(0,0,0,0));color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 35%, rgba(0,0,0,0))}.tag.warn{background:color-mix(in srgb, var(--warn) 18%, rgba(0,0,0,0));color:var(--warn);border-color:color-mix(in srgb, var(--warn) 35%, rgba(0,0,0,0))}.tag.good{background:color-mix(in srgb, var(--good) 18%, rgba(0,0,0,0));color:var(--good);border-color:color-mix(in srgb, var(--good) 35%, rgba(0,0,0,0))}.gallery-toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:20px}.gallery-toolbar input[type=search]{flex:1;min-width:220px;background:var(--bg-soft);border:1px solid var(--line);color:var(--text);padding:10px 14px;border-radius:10px;font-size:14px;font-family:var(--sans)}.gallery-toolbar input[type=search]:focus{outline:none;border-color:var(--accent)}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{padding:6px 12px;border-radius:999px;border:1px solid var(--line);background:var(--bg-soft);color:var(--text-dim);font-size:12px;cursor:pointer;user-select:none;transition:color .12s,border-color .12s,background .12s}.chip:hover{color:var(--text);border-color:var(--line-strong)}.chip.active{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#0b1020;border-color:rgba(0,0,0,0);font-weight:600}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:14px}.card{border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-soft);overflow:hidden;display:flex;flex-direction:column;transition:transform .1s ease,border-color .15s ease,box-shadow .15s ease;text-decoration:none !important;color:var(--text)}.card:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:var(--shadow)}.card .thumb{height:180px;background:#fff;display:grid;place-items:center;padding:10px;overflow:hidden}.card .thumb svg,.card .thumb img{max-width:100%;max-height:100%;height:auto}.card .meta{padding:12px 14px;display:flex;flex-direction:column;gap:4px}.card .meta .title{font-weight:600;font-size:14px;color:var(--text)}.card .meta .sub{font-size:12px;color:var(--text-mute);display:flex;gap:8px;align-items:center}.card .meta .preview{font-family:var(--mono);font-size:11px;color:var(--text-dim);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty{text-align:center;padding:40px 20px;color:var(--text-mute);border:1px dashed var(--line);border-radius:var(--radius)}.editor-shell{display:grid;grid-template-columns:1fr 1fr;gap:16px;min-height:calc(100vh - 220px);align-items:stretch}.pane{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-soft);overflow:hidden;min-height:460px}.pane>header{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--bg-elev);font-size:13px;color:var(--text-dim)}.pane>header .spacer{flex:1}.pane>header select,.pane>header button{background:rgba(0,0,0,0);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:5px 10px;font-size:12px;font-family:var(--sans);cursor:pointer}.pane>header button:hover{border-color:var(--accent)}.editor-host{flex:1;min-height:0;overflow:hidden}.editor-host .cm-editor{height:100%;font-family:var(--mono);font-size:13.5px}.diagnostics-panel{background:color-mix(in srgb, var(--bad) 10%, var(--bg-elev));border-top:1px solid color-mix(in srgb, var(--bad) 40%, var(--line));padding:6px 10px;font-family:var(--mono);font-size:12px;max-height:120px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.diag-row{display:flex;align-items:baseline;gap:8px;line-height:1.5}.diag-loc{appearance:none;background:none;border:1px solid color-mix(in srgb, var(--bad) 55%, var(--line));border-radius:4px;color:var(--bad);cursor:pointer;font-family:var(--mono);font-size:11px;padding:1px 6px;white-space:nowrap;flex-shrink:0;transition:background .1s ease,border-color .1s ease}.diag-loc:hover,.diag-loc:focus-visible{background:color-mix(in srgb, var(--bad) 18%, rgba(0,0,0,0));border-color:var(--bad);outline:none}.diag-msg{color:var(--text-dim);word-break:break-word}.diag-error .diag-loc{color:var(--bad);border-color:color-mix(in srgb, var(--bad) 55%, var(--line))}.diag-warn .diag-loc{color:var(--warn);border-color:color-mix(in srgb, var(--warn) 55%, var(--line))}.diag-info .diag-loc{color:var(--accent);border-color:color-mix(in srgb, var(--accent) 55%, var(--line))}.diag-warn{background:color-mix(in srgb, var(--warn) 8%, rgba(0,0,0,0));border-radius:4px}.diag-info{background:color-mix(in srgb, var(--accent) 8%, rgba(0,0,0,0));border-radius:4px}.preview-host{flex:1;background:#fff;display:grid;place-items:center;padding:14px;overflow:auto}.preview-host svg{max-width:100%;max-height:100%;height:auto}.preview-placeholder{color:#0b1020;text-align:center;font-size:13px;max-width:380px;padding:0 20px}.preview-placeholder .pill{display:inline-block;padding:4px 10px;border-radius:999px;background:#f1f3ff;color:#4a5285;font-family:var(--mono);font-size:11px;margin-bottom:8px}.preview-placeholder a{color:#4338ca}.preview-include-warn{width:100%;padding:10px 14px;margin-bottom:12px;border-radius:8px;background:color-mix(in srgb, #fbbf24 14%, #fff);border:1px solid color-mix(in srgb, #fbbf24 40%, #fff);color:#7c5a00;font-size:13px;text-align:center}.preview-include-warn .pill-info{display:inline-block;padding:3px 9px;border-radius:999px;background:color-mix(in srgb, #fbbf24 30%, #fff);color:#7c5a00;font-family:var(--mono);font-size:11px;margin-bottom:6px}.preview-include-warn p{margin:0;line-height:1.5}.status-bar{padding:8px 14px;border-top:1px solid var(--line);background:var(--bg-elev);font-size:12px;color:var(--text-dim);display:flex;align-items:center;gap:10px}.status-bar .dot-status{width:8px;height:8px;border-radius:50%;background:var(--text-mute)}.status-bar.ok .dot-status{background:var(--good)}.status-bar.warn .dot-status{background:var(--warn)}.status-bar.bad .dot-status{background:var(--bad)}.include-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:11px;font-family:var(--mono);border:1px solid rgba(0,0,0,0);cursor:pointer;user-select:none;transition:background .12s ease,border-color .12s ease;white-space:nowrap;position:relative}.include-pill-ok{background:color-mix(in srgb, var(--good) 14%, rgba(0,0,0,0));color:var(--good);border-color:color-mix(in srgb, var(--good) 35%, rgba(0,0,0,0))}.include-pill-warn{background:color-mix(in srgb, var(--warn) 14%, rgba(0,0,0,0));color:var(--warn);border-color:color-mix(in srgb, var(--warn) 35%, rgba(0,0,0,0))}.include-pill:hover,.include-pill:focus-visible{outline:none;filter:brightness(1.15)}.include-pill-detail{display:block;position:absolute;bottom:calc(100% + 6px);left:0;background:var(--bg-elev);border:1px solid var(--line-strong);border-radius:8px;padding:8px 12px;font-size:11px;color:var(--text-dim);white-space:pre-wrap;max-width:420px;word-break:break-all;z-index:50;box-shadow:var(--shadow)}.cm-editor.cm-focused{outline:2px solid var(--accent);outline-offset:-2px}.cm-editor{background:var(--code-bg);color:var(--text)}.cm-cursor,.cm-cursor-primary{border-left-color:var(--accent) !important}.cm-content{caret-color:var(--accent)}.cm-gutters{background:var(--code-bg);border-right:1px solid var(--line);color:var(--text-mute)}.cm-activeLine,.cm-activeLineGutter{background:color-mix(in srgb, var(--accent) 8%, rgba(0,0,0,0))}.tok-comment{color:#6f7aa8;font-style:italic}.tok-directive{color:#f472b6;font-weight:600}.tok-keyword{color:#a78bfa}.tok-lifecycle{color:#fbbf24}.tok-skin{color:#7dd3fc}.tok-arrow{color:#34d399;font-weight:600}.tok-string{color:#facc15}.tok-color{color:#f87171}.tok-number{color:#f59e0b}.tok-stereo{color:#93c5fd}.tok-bracket{color:var(--text-mute)}.puml-fence-preview{margin:18px 0;border:1px solid var(--line);border-radius:8px;background:var(--bg-soft);overflow:hidden}.puml-fence-toolbar{display:flex;align-items:center;gap:8px;min-height:38px;justify-content:flex-end;padding:5px 8px 5px 12px;border-bottom:1px solid var(--line);background:color-mix(in srgb, var(--bg-elev) 82%, rgba(0,0,0,0))}.puml-fence-lang{min-width:0;margin-right:auto;color:var(--text-mute);font-family:var(--mono);font-size:11px;line-height:1}.puml-fence-toggle{appearance:none;border:1px solid var(--line-strong);border-radius:999px;background:color-mix(in srgb, var(--bg-elev) 88%, var(--accent));color:var(--text);font-family:var(--sans);font-size:12px;font-weight:700;line-height:1;min-height:28px;padding:6px 10px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;box-shadow:0 5px 18px rgba(0,0,0,.18);transition:border-color .12s ease,background .12s ease,transform .12s ease}.puml-fence-toggle svg{width:14px;height:14px;fill:currentColor;flex:0 0 auto}.puml-fence-toggle:hover,.puml-fence-toggle:focus-visible{border-color:var(--accent);background:color-mix(in srgb, var(--bg-elev) 78%, var(--accent));outline:none}.puml-fence-toggle:hover{transform:translateY(-1px)}.puml-fence-toggle[aria-pressed=true]{border-color:color-mix(in srgb, var(--accent) 70%, var(--line-strong));background:color-mix(in srgb, var(--accent) 18%, var(--bg-elev))}.puml-fence-bubble{white-space:nowrap}.puml-fence-body{min-width:0}.puml-fence-preview pre{margin:0;border:0;border-radius:0}.puml-fence-preview.is-open .puml-fence-body{display:grid;grid-template-columns:minmax(0, 1fr) minmax(300px, .92fr);align-items:stretch}.puml-fence-preview.is-open pre{border-right:1px solid var(--line)}.puml-fence-render{min-height:180px;padding:14px;background:#fff;color:#0b1020;overflow:auto}.puml-fence-render[hidden]{display:none}.puml-fence-pages{display:grid;place-items:center;gap:18px;min-height:100%}.puml-fence-pages svg{max-width:100%;height:auto}.puml-fence-message,.puml-fence-diagnostic{display:grid;place-items:center;align-content:center;min-height:150px;text-align:center;font-size:13px}.puml-fence-diagnostic{color:#4a1d1d}.puml-fence-diagnostic .pill{display:inline-block;padding:3px 9px;border-radius:999px;background:#fee2e2;color:#991b1b;font-family:var(--mono);font-size:11px;line-height:1.4}.puml-fence-diagnostic p{max-width:46ch;margin:8px 0 0;color:inherit;line-height:1.45}.docs{display:grid;grid-template-columns:240px minmax(0, 1fr) 220px;gap:36px;padding:36px 0 60px;align-items:start}.docs .sidebar{position:sticky;top:76px;align-self:start;max-height:calc(100vh - 100px);overflow-y:auto;font-size:14px;padding-right:12px}.docs .sidebar h4{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-mute);margin:18px 0 6px}.docs .sidebar ul{list-style:none;padding:0;margin:0 0 14px}.docs .sidebar li{padding:3px 0}.docs .sidebar a{color:var(--text-dim);display:block;padding:4px 10px;border-radius:6px}.docs .sidebar a:hover{color:var(--text);background:var(--bg-soft);text-decoration:none}.docs .sidebar a.active{color:var(--text);background:color-mix(in srgb, var(--accent) 12%, rgba(0,0,0,0));border-left:2px solid var(--accent);padding-left:10px}.docs main{min-width:0}.docs main h1{font-size:36px;margin:0 0 8px;letter-spacing:-.02em}.docs main h2{font-size:24px;margin-top:36px;border-top:1px solid var(--line);padding-top:24px;letter-spacing:-.01em}.docs main h3{font-size:18px;margin-top:28px}.docs main p{color:var(--text)}.docs main p,.docs main li{line-height:1.7}.docs main ul,.docs main ol{padding-left:22px}.docs .toc{position:sticky;top:76px;align-self:start;max-height:calc(100vh - 100px);overflow-y:auto;font-size:13px}.docs .toc h4{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-mute);margin:0 0 8px}.docs .toc ul{list-style:none;padding:0;margin:0}.docs .toc li{padding:2px 0}.docs .toc a{color:var(--text-dim)}.docs .toc a:hover{color:var(--text);text-decoration:none}.callout{border:1px solid var(--line);background:var(--bg-soft);padding:14px 16px;border-radius:var(--radius);margin:16px 0;border-left:3px solid var(--accent)}.callout.warn{border-left-color:var(--warn)}.callout.good{border-left-color:var(--good)}.callout strong{color:var(--text)}footer.site-footer{border-top:1px solid var(--line);margin-top:40px;padding:28px 0 36px;color:var(--text-mute);font-size:13px}footer.site-footer .inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}footer.site-footer a{color:var(--text-dim)}footer.site-footer a:hover{color:var(--text)}@media (max-width: 1100px){.docs{grid-template-columns:220px minmax(0, 1fr)}.docs .toc{display:none}}@media (max-width: 860px){.hero .inner{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2, 1fr)}.feature-grid{grid-template-columns:1fr}.matrix{grid-template-columns:1fr}.editor-shell{grid-template-columns:1fr}.docs{grid-template-columns:1fr}.docs .sidebar{position:static;max-height:none}.puml-fence-preview.is-open .puml-fence-body{grid-template-columns:1fr}.puml-fence-preview.is-open pre{border-right:0;border-bottom:1px solid var(--line)}}@media (max-width: 600px){.container{padding:0 16px}.hero{padding:56px 0 32px}.hero-preview .split{grid-template-columns:1fr}.hero-preview pre{border-right:none;border-bottom:1px solid var(--line)}}