:root{--bg:#0f1115;--panel:#161922;--panel-2:#1d212c;--border:#2a2f3d;--text:#e6e9ef;--muted:#9aa2b2;--accent:#7aa2ff;--side-a:#ffb86c;--side-b:#8be9fd;--only-a:#f59e0b;--only-b:#06b6d4;--changed:#ef4444;--same:#22c55e;--renamed:#a855f7;--mono:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}@media (prefers-color-scheme:light){:root{--bg:#f7f8fa;--panel:#fff;--panel-2:#f1f3f7;--border:#d9deea;--text:#15171d;--muted:#5a6478}}*{box-sizing:border-box}html,html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,sans-serif;font-size:14px;line-height:1.5}@media (width>=1080px) and (width<=1619px){body{padding-left:220px}}#app{max-width:1200px;margin:0 auto;padding:32px 24px 80px}#section-nav{background:var(--panel);border:1px solid var(--border);z-index:5;border-radius:10px;width:180px;padding:12px 0;font-size:13px;position:fixed;top:24px;left:16px}#section-nav ul{margin:0;padding:0;list-style:none}#section-nav a{color:var(--muted);border-left:2px solid #0000;padding:6px 14px;text-decoration:none;display:block}#section-nav a:hover{color:var(--text);background:var(--panel-2)}#section-nav a.active{color:var(--text);border-left-color:var(--accent);background:var(--panel-2)}#section-nav li.nav-disabled{display:none}@media (width<=1080px){#section-nav{display:none}}header h1{margin:0 0 4px;font-size:24px}header .lede{color:var(--muted);margin:0 0 28px}code{font-family:var(--mono);background:var(--panel-2);border-radius:4px;padding:1px 5px;font-size:.92em}.uploaders{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px;display:grid}.uploader{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:4px}.uploader label{border:2px dashed var(--border);cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:28px 16px;transition:border-color .12s,background .12s;display:flex}.uploader label:hover,.uploader.dragover label{border-color:var(--accent);background:var(--panel-2)}.uploader-title{font-size:15px;font-weight:600}.uploader[data-side=a] .uploader-title:before{content:"";background:var(--side-a);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.uploader[data-side=b] .uploader-title:before{content:"";background:var(--side-b);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.uploader-hint{color:var(--muted);font-size:13px}.uploader-status{min-height:22px;padding:6px 12px 8px;font-size:13px}.uploader-status.ok{color:var(--same)}.uploader-status.err{color:var(--changed)}.uploader-status.loading{color:var(--muted)}.demo-btn{color:#0f1115;border:1px solid var(--border);font:inherit;cursor:pointer;background:#fff;border-radius:6px;padding:4px 12px;font-size:12px}.demo-btn:hover:not(:disabled){border-color:var(--accent)}.demo-btn:disabled{opacity:.6;cursor:progress}#instructions{background:var(--panel);border:1px solid var(--border);color:var(--muted);border-radius:10px;margin-bottom:28px;padding:20px 24px 16px}#instructions h2{color:var(--text);margin:0 0 14px;font-size:17px}#instructions h3{color:var(--text);margin:0 0 6px;font-size:14px}#instructions p{margin:0 0 8px;line-height:1.5}#instructions a{color:var(--accent)}.instructions-steps{flex-direction:column;gap:18px;margin:0;padding-left:24px;display:flex}.instructions-steps>li::marker{color:var(--muted);font-variant-numeric:tabular-nums}.instructions-code{background:var(--panel-2);border:1px solid var(--border);font-family:var(--mono);border-radius:8px;margin:8px 0;padding:12px 14px;font-size:12.5px;line-height:1.5;overflow-x:auto}.instructions-code code{font-size:inherit;background:0 0;border-radius:0;padding:0}.instructions-note{color:var(--muted);font-size:13px}.instructions-privacy{border-top:1px solid var(--border);margin:16px 0 0;padding-top:14px;font-size:13px}.summary{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px;display:grid}.stat{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:12px 14px}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:12px}.stat-num{font-variant-numeric:tabular-nums;font-size:22px;font-weight:600}.stat-row{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.stat-num.side-a{color:var(--side-a)}.stat-num.side-b{color:var(--side-b)}.stat-arrow{color:var(--muted)}.stat-delta{background:var(--panel-2);border-radius:999px;margin-left:auto;padding:2px 8px;font-size:12px}.stat-delta.pos{color:var(--only-b)}.stat-delta.neg{color:var(--only-a)}.stat-delta.zero{color:var(--muted)}.stat-only-a .stat-num{color:var(--only-a)}.stat-only-b .stat-num{color:var(--only-b)}.stat-changed .stat-num{color:var(--changed)}.stat-same .stat-num{color:var(--same)}.stat-renamed .stat-num{color:var(--renamed)}.filenames{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.pill{background:var(--panel);border:1px solid var(--border);font-size:12px;font-family:var(--mono);border-radius:999px;padding:4px 10px}.pill.side-a{border-color:var(--side-a);color:var(--side-a)}.pill.side-b{border-color:var(--side-b);color:var(--side-b)}.section{background:var(--panel);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}.section summary{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:14px 16px;list-style:none;display:flex}.section summary::-webkit-details-marker{display:none}.section summary:before{content:"▸";color:var(--muted);transition:transform .12s}.section[open] summary:before{transform:rotate(90deg)}.section-title{font-weight:600}.section-count{font-family:var(--mono);background:var(--panel-2);border-radius:999px;margin-left:auto;padding:1px 8px;font-size:12px}.section-size{font-family:var(--mono);color:var(--muted);font-size:12px}.entry-size{font-family:var(--mono);color:var(--muted);margin-left:auto;font-size:12px}.copy-md-btn{border:1px solid var(--border);color:var(--muted);font:inherit;cursor:pointer;background:0 0;border-radius:4px;margin-left:8px;padding:2px 8px;font-size:11px}.copy-md-btn:hover{color:var(--accent);border-color:var(--accent)}.section-only-a .section-title:before{content:"";background:var(--only-a);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.section-only-b .section-title:before{content:"";background:var(--only-b);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.section-changed .section-title:before{content:"";background:var(--changed);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.section-same .section-title:before{content:"";background:var(--same);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.section-renamed .section-title:before{content:"";background:var(--renamed);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.entry-arrow{color:var(--muted);margin:0 6px}.entry-key-from{color:var(--side-a)}.entry-key-to{color:var(--side-b)}.entries{border-top:1px solid var(--border);margin:0;padding:0;list-style:none}.entry{border-bottom:1px solid var(--border);padding:14px 16px}.entry:last-child{border-bottom:none}.entry-header{flex-wrap:wrap;align-items:baseline;gap:12px;display:flex}.entry-key{font-family:var(--mono);background:0 0;padding:0;font-size:13px}.entry-meta{color:var(--muted);font-size:12px}.changes{margin:8px 0 0;padding-left:18px}.changes li{font-family:var(--mono);color:var(--text);font-size:12.5px}.entry-grid{grid-template-columns:1fr 1fr;gap:12px;margin-top:10px;display:grid}.entry-col{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:10px 12px}.entry-col.side-a{border-left:3px solid var(--side-a)}.entry-col.side-b{border-left:3px solid var(--side-b)}.entry-col-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px}.entry-col-empty{color:var(--muted);font-size:13px;font-style:italic}.entry-col dl{grid-template-columns:max-content 1fr;gap:4px 10px;margin:0;font-size:12.5px;display:grid}.entry-col dt{color:var(--muted);font-family:var(--mono)}.entry-col dd{font-family:var(--mono);word-break:break-all;margin:0}.empty{color:var(--muted);border-top:1px solid var(--border);margin:0;padding:14px 16px}.uploader-status .err-line{color:var(--changed)}.uploader-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.vite-version-badge{font-family:var(--mono);color:var(--accent);background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:1px 8px;font-size:11px;display:inline-block}.snapshot-label{color:var(--text);background:var(--panel-2);border:1px solid var(--accent);border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600;display:inline-block}.uploaders-toolbar{grid-template-columns:1fr 1fr;align-items:center;margin:-16px 0 24px;display:grid}.uploaders-toolbar .demo-btn{grid-column:1;justify-self:start}.uploaders-toolbar .clear-btn{grid-column:2;justify-self:end}.clear-btn{color:var(--muted);border:1px solid var(--border);font:inherit;cursor:pointer;background:0 0;border-radius:6px;padding:4px 12px;font-size:12px}.clear-btn:hover{color:var(--changed);border-color:var(--changed)}#entry-analysis{margin-top:32px}.analysis-title{margin:0 0 4px;font-size:18px}.analysis-subtitle{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:24px 0 8px;font-size:14px}.analysis-note{color:var(--muted);margin:0 0 12px}.analysis-table{border-collapse:collapse;background:var(--panel);border:1px solid var(--border);border-radius:10px;width:100%;font-size:13px;overflow:hidden}.analysis-table th,.analysis-table td{text-align:right;font-variant-numeric:tabular-nums;padding:8px 12px}.analysis-table thead th{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--border);background:var(--panel-2);font-size:11px;font-weight:600}.analysis-table tbody tr+tr th,.analysis-table tbody tr+tr td{border-top:1px solid var(--border)}.analysis-table .row-label{text-align:left;color:var(--muted);font-weight:500}.analysis-table .col-side{font-family:var(--mono)}.analysis-table thead .col-a,.analysis-table tbody .col-a{color:var(--side-a)}.analysis-table thead .col-b,.analysis-table tbody .col-b{color:var(--side-b)}.analysis-table .col-delta{font-family:var(--mono);font-size:12px}.analysis-table .col-delta.pos{color:var(--only-b)}.analysis-table .col-delta.neg{color:var(--only-a)}.analysis-table .col-delta.zero{color:var(--muted)}.entry-list{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.entry-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.entry-card-header{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.entry-card-name{font-weight:600;font-family:var(--mono);font-size:13px}.entry-card-presence{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.entry-card-kind{font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em;background:var(--panel-2);border-radius:999px;padding:1px 8px;font-size:10px}.entry-card-kind.kind-static{color:var(--accent);border:1px solid var(--accent)}.entry-card-kind.kind-dynamic{color:var(--side-a);border:1px solid var(--side-a)}.entry-card-facade{font-family:var(--mono);color:var(--muted);background:var(--panel-2);word-break:break-all;border-radius:4px;margin-left:auto;padding:1px 6px;font-size:11px}.entry-table{border-radius:6px}#module-diff{margin-top:32px}.module-diff-header h2,.chunk-diff-header h2{margin:0 0 4px;font-size:18px}.module-diff-note,.chunk-diff-note{color:var(--muted);margin:0 0 12px}.analysis-subtitle-row{align-items:baseline;gap:12px;margin:24px 0 8px;display:flex}.analysis-subtitle-row .analysis-subtitle{margin:0}.analysis-subtitle-hint{color:var(--muted);font-size:12px}.entry-search{margin:0 0 12px}.entry-search-input{background:var(--panel);color:var(--text);border:1px solid var(--border);font:inherit;border-radius:6px;width:320px;max-width:100%;padding:6px 10px;font-size:13px}.entry-search-input:focus{border-color:var(--accent);outline:none}.module-list{border-top:1px solid var(--border);margin:0;padding:0;list-style:none}.module-row{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:baseline;gap:12px;padding:8px 16px;display:flex}.module-row:last-child{border-bottom:none}.module-id{font-family:var(--mono);word-break:break-all;background:0 0;flex:auto;padding:0;font-size:12.5px}.module-meta{color:var(--muted);font-size:12px;font-family:var(--mono);align-items:center;gap:10px;display:inline-flex}.module-chunk,.chunk-from,.chunk-to{background:var(--panel-2);border-radius:999px;padding:1px 8px}.chunk-from{color:var(--side-a);border:1px solid var(--side-a);background:0 0}.chunk-to{color:var(--side-b);border:1px solid var(--side-b);background:0 0}.chunk-arrow{color:var(--muted)}.module-size{color:var(--muted);white-space:nowrap}#graph-section{margin-top:32px}.graph-header h2{margin:0 0 4px;font-size:18px}.graph-note{color:var(--muted);margin:0 0 12px}.graph-toolbar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.graph-tab{background:var(--panel);color:var(--text);border:1px solid var(--border);font:inherit;cursor:pointer;border-radius:6px;padding:6px 12px}.graph-tab:hover:not(:disabled){border-color:var(--accent)}.graph-tab.active{border-color:var(--accent);background:var(--panel-2);color:var(--accent)}.graph-tab:disabled{opacity:.4;cursor:not-allowed}.graph-search{align-items:center;gap:6px;display:inline-flex}.graph-search-input{background:var(--panel);color:var(--text);border:1px solid var(--border);font:inherit;border-radius:6px;width:200px;padding:6px 10px;font-size:13px}.graph-search-input:focus{border-color:var(--accent);outline:none}.graph-search-count{color:var(--muted);font-size:11px;font-family:var(--mono)}.graph-legend{flex-wrap:wrap;gap:14px;margin-left:auto;display:flex}.legend-item{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:inline-flex}.legend-swatch{border-radius:2px;width:12px;height:12px;display:inline-block}.legend-swatch.module-same{background:#475569}.legend-swatch.module-moved{background:#f59e0b}.legend-swatch.module-only-here{background:#ef4444}.graph-canvas{background:var(--panel);border:1px solid var(--border);touch-action:none;border-radius:10px;height:720px;overflow:hidden}.graph-empty{height:100%;color:var(--muted);justify-content:center;align-items:center;display:flex}.graph-svg{cursor:grab;display:block}.graph-tooltip{background:var(--panel-2);color:var(--text);border:1px solid var(--border);pointer-events:none;z-index:200;border-radius:6px;max-width:60vw;padding:6px 10px;font-size:12px;position:fixed;box-shadow:0 4px 16px #00000059}.graph-tooltip-id{font-family:var(--mono);word-break:break-all;font-size:12.5px}.graph-tooltip-meta{color:var(--muted);font-size:11px;font-family:var(--mono);margin-top:2px}.cluster{fill:var(--panel-2);fill-opacity:.6;stroke:var(--border);stroke-width:1.5px}.cluster-entry{stroke:var(--accent);stroke-width:2px}.cluster-dynamic{stroke-dasharray:6 4}.cluster-label{font-family:var(--mono);fill:var(--text);pointer-events:none;font-size:11px}.edge{fill:none;stroke:var(--muted);stroke-width:1.2px;opacity:.7;color:var(--muted)}.edge-dynamic{stroke-dasharray:5 4}.edge.edge-hidden,.cluster-hidden{display:none}.hidden-chunks{margin-top:12px}.hidden-chunks:empty{display:none}.hidden-chunks-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:6px;font-size:11px}.hidden-chunks-list{flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.hidden-chunks-item{background:var(--panel);border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;padding:3px 4px 3px 10px;display:inline-flex}.hidden-chunks-show{color:var(--muted);border:1px solid var(--border);font:inherit;cursor:pointer;background:0 0;border-radius:999px;padding:1px 8px;font-size:11px}.hidden-chunks-show:hover{color:var(--accent);border-color:var(--accent)}.cluster-menu{background:var(--panel);border:1px solid var(--border);z-index:200;border-radius:6px;min-width:200px;padding:4px 0;position:fixed;box-shadow:0 4px 16px #00000059}.cluster-menu-header{font-family:var(--mono);color:var(--muted);border-bottom:1px solid var(--border);word-break:break-all;margin-bottom:4px;padding:4px 12px 6px;font-size:11px}.cluster-menu-item{text-align:left;width:100%;color:var(--text);font:inherit;cursor:pointer;background:0 0;border:none;padding:6px 12px;font-size:13px;display:block}.cluster-menu-item:hover{background:var(--panel-2);color:var(--accent)}.module{cursor:default;stroke-width:1px}.module-same{fill:#475569;stroke:#64748b}.module-moved{fill:#f59e0b;stroke:#fbbf24}.module-only-here{fill:#ef4444;stroke:#f87171}.module:hover{stroke:var(--accent);stroke-width:2px}.module.module-match{fill:#22c55e;stroke:#16a34a;stroke-width:2.5px;filter:drop-shadow(0 0 6px #22c55ecc)}.module-row.clickable{cursor:pointer}.module-row.clickable:hover{background:var(--panel-2)}#inspector{background:var(--panel);border-left:1px solid var(--border);z-index:100;flex-direction:column;width:460px;max-width:100vw;height:100vh;display:flex;position:fixed;top:0;right:0;box-shadow:-8px 0 24px #00000040}#inspector[hidden]{display:none}.inspector-header{border-bottom:1px solid var(--border);align-items:center;padding:14px 16px;display:flex}.inspector-title{margin:0;font-size:15px}.inspector-close{color:var(--muted);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:0 6px;font-size:24px;line-height:1}.inspector-close:hover{color:var(--text)}.inspector-body{flex:1;padding:14px 16px;overflow:auto}.inspector-id-label,.inspector-section-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 4px;font-size:11px}.inspector-section-label{margin-top:16px}.inspector-id{font-family:var(--mono);word-break:break-all;background:var(--panel-2);border-radius:6px;margin-bottom:12px;padding:8px 10px;font-size:12.5px;display:block}.inspector-side-toggle{gap:6px;margin:8px 0 0;display:flex}.inspector-chunk{font-family:var(--mono);background:var(--panel-2);border-radius:4px;padding:4px 8px;font-size:12.5px;display:inline-block}.inspector-note{color:var(--muted);margin:8px 0 0;font-size:13px}.inspector-note.warn{color:var(--side-a)}.inspector-paths{margin:6px 0 0;padding-left:22px;list-style:decimal}.trace-path{margin-bottom:14px}.trace-header{align-items:center;gap:8px;margin-bottom:6px;font-size:12px;display:flex}.trace-root-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:10px}.trace-root-chunk{font-family:var(--mono);background:var(--panel-2);border:1px solid var(--accent);color:var(--accent);border-radius:999px;padding:1px 8px}.trace-chain{flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.trace-node{font-family:var(--mono);background:var(--panel-2);word-break:break-all;border:1px solid #0000;border-radius:4px;padding:2px 6px}.trace-node.clickable{cursor:pointer}.trace-node.clickable:hover,.trace-node.clickable:focus-visible{border-color:var(--accent);color:var(--accent);outline:none}.trace-arrow{color:var(--muted)}.trace-arrow-dynamic{color:var(--side-a)}.inspector-section-row{align-items:center;gap:12px;margin-top:16px;margin-bottom:4px;display:flex}.inspector-section-row .inspector-section-label{margin:0}.inspector-legend{color:var(--muted);gap:12px;margin-left:auto;font-size:11px;display:inline-flex}.legend-pair{align-items:center;gap:4px;display:inline-flex}.inspector-deps{margin:4px 0 0;padding:0;list-style:none}.dep-row{align-items:center;gap:8px;padding:4px 0;font-size:12px;display:flex}.dep-chunk{font-family:var(--mono);color:var(--muted);background:var(--panel-2);white-space:nowrap;border-radius:999px;margin-left:auto;padding:1px 8px;font-size:11px}@media (width<=720px){.uploaders,.entry-grid{grid-template-columns:1fr}.graph-canvas{height:520px}#inspector{border-left:none;border-top:1px solid var(--border);width:100vw}}
