*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--surface: #f7f7f7;--surface2: #f0f0f0;--border: #e8e8e8;--accent: #111111;--accent2: #10b98a;--text: #111111;--muted: #6b6b6b;--danger: #dc2626;--radius: 8px;--mono: "Fira Code", "Cascadia Code", Consolas, monospace}body{background:var(--bg);color:var(--text);font-family:system-ui,sans-serif;min-height:100vh;display:flex;flex-direction:column}header{padding:1rem 2rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1rem}header a{text-decoration:none;color:inherit;display:flex;align-items:center;gap:.6rem}.logo{font-size:1.6rem;font-weight:700;letter-spacing:-.5px}.logo span{color:var(--muted);font-weight:400}.tagline{color:var(--muted);font-size:.85rem}main{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}footer{padding:1rem 2rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--muted);text-align:center}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;border-radius:6px;border:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:opacity .15s}.btn:hover{opacity:.75}.btn:active{opacity:.6}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--border)}.upload-section{margin-bottom:2rem}.section-label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:3.5rem;text-align:center;cursor:pointer;position:relative;transition:border-color .2s,background .2s}.dropzone.drag-over{border-color:var(--text);background:#00000005}.dropzone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.dropzone-icon{font-size:5rem;margin-bottom:.5rem;display:block;line-height:1}.dropzone-label{color:var(--muted);font-size:.95rem}.dropzone-label strong{color:var(--text)}.dropzone-hint{font-size:.8rem;color:var(--muted);margin-top:.4rem}.upload-controls{margin-top:1rem;display:flex;gap:.75rem;align-items:center}.file-name{font-size:.85rem;color:var(--muted)}.paste-area{margin-top:1.25rem}.paste-divider{display:flex;align-items:center;gap:.75rem;color:var(--muted);font-size:.8rem;margin-bottom:.75rem}.paste-divider:before,.paste-divider:after{content:"";flex:1;height:1px;background:var(--border)}.paste-input{width:100%;resize:vertical;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;color:var(--text);font-family:var(--mono);font-size:.82rem;line-height:1.5;outline:none;transition:border-color .15s}.paste-input:focus{border-color:var(--text)}.share-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.4rem;margin-bottom:1.5rem}.share-card-label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}.share-row{display:flex;gap:.5rem;align-items:center}.share-url{flex:1;background:#fff;border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;color:var(--text);font-family:var(--mono);font-size:.85rem;outline:none;cursor:text}.share-meta{display:flex;gap:.6rem;margin-top:.7rem;flex-wrap:wrap}.meta-chip{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:.15rem .65rem;font-size:.75rem;color:var(--muted)}.meta-chip strong{color:var(--text)}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.tab{padding:.55rem 1rem;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--muted);font-size:.875rem;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab:hover{color:var(--text)}.tab.active{color:var(--text);font-weight:600;border-bottom-color:var(--text)}.graph-layout{display:flex;gap:1rem;align-items:flex-start}.graph-canvas-wrap{flex:1;min-width:0;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;position:relative}.graph-canvas-wrap svg{display:block;width:100%;height:580px}.graph-hint{position:absolute;bottom:.75rem;left:50%;transform:translate(-50%);font-size:.72rem;color:var(--muted);pointer-events:none;white-space:nowrap}.graph-toolbar{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem}.graph-hops-label{font-size:.85rem;color:var(--muted)}.link-btn{background:none;border:none;padding:0;color:var(--accent);font-size:inherit;cursor:pointer;text-decoration:underline;font-weight:500}.link-btn:hover{opacity:.7}.node-detail{width:300px;flex-shrink:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;max-height:580px;display:flex;flex-direction:column}.node-detail-header{padding:1rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;background:var(--surface)}.node-type-badge{display:inline-block;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;border-radius:4px;padding:.15rem .45rem;margin-bottom:.35rem}.node-type-badge[data-type=uri]{background:#ede9fd;color:#6b5ce7;border:1px solid #d0c8f8}.node-type-badge[data-type=bnode]{background:#f0f0f5;color:#666;border:1px solid #d8d8e8}.node-type-badge[data-type=literal]{background:#e8f9f5;color:#2a9e87;border:1px solid #b8ede4}.node-label{font-size:.95rem;font-weight:600;color:var(--text);word-break:break-all;line-height:1.3}.node-id{font-size:.72rem;color:var(--muted);font-family:var(--mono);margin-top:.25rem;word-break:break-all}.close-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.2rem;line-height:1;padding:0;flex-shrink:0}.close-btn:hover{color:var(--text)}.node-detail-body{padding:.75rem;overflow-y:auto;flex:1}.relation-group{margin-bottom:1rem}.relation-group:last-child{margin-bottom:0}.relation-group-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.5rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}.relation-row{display:flex;flex-direction:column;gap:.15rem;padding:.4rem .5rem;border-radius:6px;margin-bottom:.25rem;background:var(--surface)}.relation-pred{font-size:.72rem;color:#9b94e8;font-family:var(--mono);word-break:break-all}.relation-obj{font-size:.78rem;color:var(--text);word-break:break-all}.literal-value{color:#3db898;font-family:var(--mono)}.search-row{display:flex;gap:.5rem;margin-bottom:.75rem}.search-input{flex:1;background:#fff;border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;color:var(--text);font-size:.875rem;outline:none}.search-input:focus{border-color:var(--text)}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.85rem}thead th{background:var(--surface);padding:.6rem .9rem;text-align:left;color:var(--muted);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}tbody tr{border-bottom:1px solid var(--border)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface)}td{padding:.5rem .9rem;font-family:var(--mono);font-size:.78rem;word-break:break-all}td.col-s{color:#3fa8d8}td.col-p{color:#8f87e0}td.col-o{color:#3db898}.format-bar{display:flex;gap:.5rem;align-items:center;margin-bottom:.75rem;flex-wrap:wrap}.format-bar label{font-size:.85rem;color:var(--muted)}select{background:#fff;border:1px solid var(--border);border-radius:6px;padding:.35rem .6rem;color:var(--text);font-size:.85rem;outline:none;cursor:pointer}pre{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;overflow:auto;font-family:var(--mono);font-size:.82rem;line-height:1.6;color:var(--muted);max-height:560px;white-space:pre-wrap;word-break:break-all}.loading{display:flex;align-items:center;gap:.6rem;color:var(--muted);font-size:.9rem;padding:1.5rem 0}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.empty{color:var(--muted);font-size:.9rem;padding:2rem 0;text-align:center}.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1.1rem;font-size:.875rem;max-width:340px;box-shadow:0 2px 12px #00000014;z-index:999;animation:toast-in .2s ease}.toast.error{border-color:var(--danger);color:var(--danger)}.toast.success{border-color:var(--accent2)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media (max-width: 700px){main{padding:1rem}.dropzone{padding:1.5rem}.graph-layout{flex-direction:column}.node-detail{width:100%;max-height:400px}}
