*,:before,:after{box-sizing:border-box}body{color:#1a1a1a;background:#f8f9fa;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;line-height:1.6}.app{max-width:900px;margin:0 auto;padding:2rem 1.5rem 4rem}.app-header{align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.logo{width:auto;height:48px}.app-header h1{color:#0f172a;margin:0;font-size:2rem;font-weight:700}.github-link{color:#374151;align-items:center;gap:.4rem;margin-left:auto;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .15s;display:inline-flex}.github-link:hover{color:#0f172a}.description{color:#4b5563;max-width:700px;margin:0 0 2.5rem;font-size:.975rem}.usage-section{margin-bottom:2.5rem}.usage-section h2{color:#0f172a;margin:0 0 .75rem;font-size:1.15rem;font-weight:600}.install-block{background:#1e1e1e;border:1px solid #2d2d2d;border-radius:6px;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.65rem 1rem;font-family:Menlo,Consolas,Monaco,monospace;display:flex}.install-prompt{color:#60a5fa;-webkit-user-select:none;user-select:none;font-size:.85rem}.install-cmd{color:#e2e8f0;flex:1;font-size:.85rem}.install-copy{color:#9ca3af;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #3f3f46;border-radius:4px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.75rem;transition:color .15s,border-color .15s;display:inline-flex}.install-copy:hover{color:#e2e8f0;border-color:#60a5fa}.install-copy-label{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.code-tabs{border:1px solid #2d2d2d;border-radius:6px;overflow:hidden}.code-tab-bar{background:#1e1e1e;border-bottom:1px solid #2d2d2d;gap:0;display:flex;overflow-x:auto}.code-tab-btn{color:#9ca3af;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:.5rem 1rem;font-family:Menlo,Consolas,Monaco,monospace;font-size:.78rem;transition:color .15s,border-bottom-color .15s}.code-tab-btn:hover{color:#e2e8f0}.code-tab-btn--active{color:#e2e8f0;border-bottom-color:#60a5fa}.code-tab-panel>pre{margin:0!important}.test-section h2{color:#0f172a;letter-spacing:.01em;margin:0 0 .75rem;font-size:1.15rem;font-weight:600}.test-list{flex-direction:column;gap:.35rem;display:flex}.test-row{background:#fff;border:1px solid #e5e7eb;border-radius:8px;transition:box-shadow .15s;overflow:hidden}.test-row:hover{box-shadow:0 2px 8px #00000012}.test-row.loading{cursor:default}.test-summary:focus-visible,.event-header:focus-visible{outline-offset:-3px;border-radius:6px;outline:3px solid #2563eb}.test-summary{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.65rem;min-height:64px;padding:.65rem 1rem;display:flex}.event-header{flex-wrap:wrap;align-items:center;gap:.65rem;min-height:44px;display:flex}.test-summary:hover{background:#f9fafb}.status-icon{text-align:center;flex-shrink:0;width:1.25rem;font-size:1rem;font-weight:700}.status-icon.pass{color:#16a34a}.status-icon.fail{color:#dc2626}.status-icon.loading-spinner{border:2px solid #d1d5db;border-top-color:#6b7280;border-radius:50%;flex-shrink:0;width:.9rem;height:.9rem;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.test-name{color:#111827;flex-shrink:0;font-size:.925rem;font-weight:600}.test-meta{color:#6b7280;font-size:.85rem}.test-timing{color:#6b7280;font-size:.825rem}.error-msg{color:#dc2626}.expand-arrow{color:#6b7280;flex-shrink:0;margin-left:auto;font-size:1.7rem;transition:transform .15s;display:inline-block;transform:rotate(90deg)}.expand-arrow.open{transform:translate(-8px)rotate(270deg)}.test-details{border-top:1px solid #e5e7eb;flex-direction:column;gap:1.25rem;padding:1rem 1rem 1.25rem;display:flex}.detail-section h4{text-transform:uppercase;letter-spacing:.07em;color:#6b7280;margin:0 0 .5rem;font-size:.8rem;font-weight:600}.steps-list{flex-direction:column;gap:.4rem;display:flex}.event{border-left:3px solid #0000;border-radius:5px;flex-direction:column;gap:.25rem;padding:.5rem .75rem;font-size:.85rem;display:flex}.event-label{color:#374151;font-weight:600}.event-detail{color:#6b7280;word-break:break-all;margin-top:3px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.8rem}.event-step-group{background:#f0fdf4;border-color:#4ade80;transition:background .15s,border-color .15s}.event-step-group--open{background:#dcfce7;border-color:#16a34a}.event-step-group--open .event-label{color:#15803d}.event-step-group--open .event-detail{color:#166534}.event-step-group--open .expand-arrow{color:#15803d}.step-group-body{border-left:2px solid #bbf7d0;flex-direction:column;gap:.6rem;margin-top:.4rem;padding-left:.75rem;display:flex}.step-group-section{flex-direction:column;gap:.3rem;display:flex}.step-group-label{text-transform:uppercase;letter-spacing:.06em;color:#6b7280;font-size:.75rem;font-weight:600}.event-query{background:#f0f9ff;border-color:#38bdf8}.event-step-complete{background:#f0fdf4;border-color:#4ade80}.event-nested{background:#fefce8;border-color:#facc15}.event-graph{background:#faf5ff;border-color:#c084fc}.sparql-query{color:#e2e8f0;white-space:pre;background:#0f172a;border-radius:4px;margin:.35rem 0 0;padding:.5rem .65rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.78rem;line-height:1.5;overflow-x:auto}.turtle-output{color:#7dd3fc;white-space:pre;background:#0f172a;border-radius:5px;margin:0;padding:.75rem 1rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.8rem;line-height:1.6;overflow-x:auto}.error-detail{color:#991b1b;white-space:pre-wrap;background:#fef2f2;border-radius:5px;margin:0;padding:.75rem 1rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.8rem;overflow-x:auto}.iri-display{color:#7dd3fc;background:#0f172a;border-radius:4px;padding:.35rem .65rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem;display:inline-block}.section-subtitle{color:#6b7280;text-transform:none;letter-spacing:0;font-size:.78rem;font-weight:400}.branch-tree{background:#0f172a;border-left:3px solid #4ade80;border-radius:5px;flex-direction:column;gap:.25rem;margin:.5rem 0 0;padding:.6rem .75rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.8rem;display:flex}.branch-row{align-items:baseline;gap:.5rem;line-height:1.6;display:flex}.branch-connector{color:#94a3b8;text-align:center;flex-shrink:0;width:1rem}.branch-path{color:#e2e8f0;font-weight:500}.branch-row.branch-shape .branch-path{color:#d8b4fe}.branch-count{color:#86efac;font-size:.75rem}.branch-row.branch-shape .branch-count{color:#d8b4fe}.branch-done{color:#475569;font-size:.72rem;font-style:italic}.nested-fetch-modal{background:#fff;border:none;border-radius:10px;width:min(860px,92vw);max-height:88vh;padding:0;overflow-y:auto;box-shadow:0 24px 64px #00000059}.nested-fetch-modal::backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c}.nested-fetch-modal-content{flex-direction:column;display:flex}.nested-fetch-modal-header{z-index:1;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1rem 1.25rem .75rem;display:flex;position:sticky;top:0}.nested-fetch-modal-header h3{color:#1e293b;margin:0;font-size:1rem;font-weight:600}.modal-close{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:background .15s,color .15s;display:flex}.modal-close:hover{color:#1e293b;background:#f1f5f9}.modal-close:focus-visible{outline-offset:2px;outline:3px solid #2563eb}.nested-fetch-modal .test-details{padding:1.25rem}
