:root{--bg:#0a0b0e;--panel:#111317;--panel-2:#15181d;--border:#22262e;--border-strong:#3a3f49;--text:#eceef1;--muted:#8b919c;--subtle:#5a5f69;--accent:#b8ff66;--accent-soft:rgba(184,255,102,0.18);--warn:#ffb347;--danger:#ff6e8a}.layout *{box-sizing:border-box}.layout{display:grid;grid-template-columns:260px minmax(0,1fr) 380px;height:100%;min-height:600px;background:var(--bg);color:var(--text);font-family:var(--font-sans-next),ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;font-size:14px;color-scheme:dark}html:has(>body>#root>.layout) body{margin:0;background:var(--bg)}html:has(>body>#root>.layout){height:100%}html:has(>body>#root>.layout) body{height:100vh}#root:has(>.layout){height:100%}.sidebar{border-right:1px solid var(--border);overflow-y:auto;padding:12px;background:var(--panel)}.sidebar-brand{display:flex;flex-direction:column;gap:10px;padding:4px 4px 12px;border-bottom:1px solid var(--border);margin-bottom:4px}.sidebar-logo{width:168px;max-width:80%;height:auto;display:block;margin:8px auto 4px}.book-switcher{display:flex;align-items:center;gap:6px}.book-switcher-label,.sidebar-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.sidebar-title{margin:16px 0 6px}.tree{list-style:none;margin:0;padding-left:12px}.tree-composition,.tree-folder{cursor:pointer;font-weight:600;padding:2px 0}.link,.tree-item{display:inline-flex;align-items:center;gap:6px;width:100%;text-align:left;background:none;border:none;padding:3px 6px;border-radius:5px;color:var(--text);cursor:pointer;font:inherit}.tree-item:hover{background:var(--panel-2);color:var(--text)}.tree-item.active{background:var(--accent-soft);color:var(--accent);border-left:2px solid var(--accent);border-radius:0 4px 4px 0;padding-left:4px}.link{width:auto;color:var(--accent);padding:0;text-decoration:underline}.swatch{width:10px;height:10px;border-radius:2px;flex:none}.canvas{overflow-y:auto;padding:20px 24px}.canvas-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.canvas-title{font-size:18px;margin:0;display:flex;align-items:center;gap:8px}.legend{list-style:none;display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:0 0 14px;font-size:12px;color:var(--muted)}.legend li{display:inline-flex;align-items:center;gap:5px}.prompt{display:flex;flex-direction:column;gap:14px}.segment{position:relative;margin:0;padding:16px 12px 12px;border-radius:6px;color:var(--text);white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:13px;line-height:1.5}.segment,.segment-tag{border:1px solid var(--border)}.segment-tag{position:absolute;top:0;right:0;font-size:10px;padding:2px 8px;background:rgba(0,0,0,.32);border-top:none;border-right:none;border-bottom-left-radius:6px;font-family:var(--font-mono-next),ui-monospace,"SF Mono",Menlo,monospace;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.rail{border-left:1px solid var(--border);overflow-y:auto;padding:16px;background:var(--panel)}.addons section,.rail section{margin-bottom:18px}.addons h3,.rail h3{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 8px}.rail h4{margin:12px 0 4px;font-size:12px}input,select{width:100%;padding:5px 8px;border:1px solid var(--border);border-radius:4px;font:inherit;background:var(--panel-2);color:var(--text)}input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.book-switcher select{flex:1;width:auto}.control-row{display:grid;grid-template-columns:90px 1fr;align-items:center;gap:8px;margin-bottom:6px}.control-key{font-family:ui-monospace,monospace;font-size:12px;color:var(--muted)}.control-add{display:grid;grid-template-columns:1fr auto;gap:6px;margin-top:6px}.control-add button{border:1px solid var(--border);border-radius:4px;background:var(--panel-2);color:var(--text);cursor:pointer;padding:0 12px}.control-add button:hover{border-color:var(--accent);color:var(--accent)}.findings,.rules,.used-list,.warnings{list-style:none;margin:0;padding:0}.rules li{display:grid;grid-template-columns:18px 1fr;gap:4px 6px;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px;line-height:1.4}.rules li:last-child{border-bottom:none}.rule-mark{font-weight:700;text-align:center}.rule-fired .rule-mark{color:var(--accent)}.rule-skipped{color:var(--muted)}.rule-skipped .rule-mark{opacity:.5}.rule-body{min-width:0}.rule-head{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline}.rule-action{font-weight:600;font-family:ui-monospace,monospace;color:var(--text)}.rule-skipped .rule-action,.rule-when{color:var(--muted)}.rule-when{font-size:11px}.rule-effect,.rule-when{font-family:ui-monospace,monospace}.rule-effect{margin:4px 0 0;color:var(--text)}.rule-reason{color:var(--muted);margin:4px 0 0;font-style:italic;font-size:11px}.skipped-block{margin-top:10px;border-top:1px dashed var(--border);padding-top:8px}.skipped-summary{cursor:pointer;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;list-style:none;padding:2px 0}.skipped-summary::-webkit-details-marker{display:none}.skipped-summary:before{content:"▸";display:inline-block;margin-right:6px;transition:transform .12s ease}.skipped-block[open] .skipped-summary:before{transform:rotate(90deg)}.effects{display:grid;grid-template-columns:80px 1fr;gap:4px 8px;margin:8px 0;font-size:12px}.effects dt{color:var(--muted);text-transform:uppercase;font-size:10px;letter-spacing:.06em;padding-top:2px}.effects dd,.effects dt{font-family:ui-monospace,monospace}.effects dd{margin:0;word-break:break-word}.notice{margin:8px 0 0;font-size:12px;color:var(--text);background:rgba(255,179,71,.08);border:1px solid rgba(255,179,71,.35);border-radius:5px;padding:8px 10px}.notice strong{display:block;color:var(--warn);font-size:11px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.small{font-size:11px}.order{font-family:ui-monospace,monospace;font-size:12px;word-break:break-word}.finding{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;padding:5px 0;border-bottom:1px solid var(--border);font-size:12px}.finding-sev{text-transform:uppercase;font-size:10px;font-weight:700;letter-spacing:.08em;padding:2px 6px;border-radius:3px;background:var(--panel-2);color:var(--muted)}.finding.error .finding-sev{background:rgba(255,110,138,.14);color:var(--danger)}.finding.warning .finding-sev{background:rgba(255,179,71,.14);color:var(--warn)}.finding-rule{color:var(--muted)}.diff-body,.finding-rule{font-family:ui-monospace,monospace}.diff-body{margin:8px 0 0;font-size:12px;border:1px solid var(--border);border-radius:6px;overflow-x:auto;background:var(--panel-2)}.diff-row{padding:0 8px;white-space:pre-wrap}.diff-row.add{background:rgba(184,255,102,.1);color:var(--accent)}.diff-row.remove{background:rgba(255,110,138,.12);color:var(--danger)}.diff-mark{display:inline-block;width:12px;color:var(--muted)}.annot-mark{background:rgba(255,179,71,.18);border-bottom:2px solid var(--warn);border-radius:2px;padding:0 1px;color:var(--text)}.annot-popover{position:fixed;z-index:20;width:280px;padding:12px;background:var(--panel);border:1px solid var(--border-strong);border-radius:6px;box-shadow:0 16px 40px rgba(0,0,0,.6);color:var(--text)}.annot-popover textarea{width:100%;min-height:64px;resize:vertical;margin:6px 0}.annot-actions{display:flex;justify-content:flex-end;gap:10px;align-items:center}.annot-actions button[type=button]:last-child{border:1px solid var(--accent);border-radius:4px;background:var(--accent);color:var(--bg);padding:4px 12px;cursor:pointer;font-weight:600}.annot-actions button[type=button]:last-child:hover{background:transparent;color:var(--accent)}.annot-actions button[disabled]{opacity:.5;cursor:default}.annot-quote{margin:0;font-style:italic;color:var(--muted);font-size:12px;word-break:break-word}.annot-list{list-style:none;margin:0;padding:0}.annot-list li{padding:8px 0;border-bottom:1px solid var(--border)}.annot-comment{margin:4px 0;font-size:13px;word-break:break-word}.annot-meta{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:12px}.badge{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--panel-2);color:var(--muted);border:1px solid var(--border);white-space:nowrap}.badge-code{font-size:10px;text-transform:uppercase;letter-spacing:.08em;background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:700}.code-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.code-tab{font:inherit;font-size:12px;padding:4px 12px;border-radius:999px;border:1px solid var(--border);background:var(--panel);color:var(--muted);cursor:pointer;font-family:var(--font-mono-next),ui-monospace,monospace}.code-tab:hover{color:var(--text);border-color:var(--border-strong)}.code-tab.active{background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:600}.code-diff{margin-top:18px}.tokens{font-size:20px;font-weight:600;margin:0}.muted{color:var(--muted)}.warn{color:var(--warn)}.used-list li{padding:3px 0}